15
12

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

バックエンドAPIとフロントエンドの設計で思ったこと

Last updated at Posted at 2017-03-05

はじめに

Play FrameworkをバックエンドAPIとして使って、Reactをフロンドエンドとして使ったときに思ったことです。

データの計算はバックエンドAPIとWebフロントエンドのどちらがやるべきか

sandboxとproductionのDBの差分をWebフロントエンドで計算していました。
これはバックエンドAPIにデータ計算をさせるべきかなと思います。
理由はロジックが複雑になってくると、型がないのでバグが紛れ込む可能性が上がることです。特にフロントエンドはUIの変更が頻繁に発生していたので、毎回何かの型がタイプミスマッチが出てChrome DevToolsのコンソールが真っ赤になっていました。

Webフロントエンドのリクエストパラメータを信頼しすぎない

Webブラウザ上からバックエンドAPIを叩いているだけなので、バックエンドAPIが許可していればどのようなリクエストパラメータでもリクエストできます。そして、Webブラウザ上実行されている性質上データの書き換えが可能です。バックエンドAPIのリクエストパラメータ取得時と業務ロジックで適切にバリデーションをしておけば問題ありませんが、Webフロントエンドのデータを盲目的に信じてしまうのはよくありません。バックエンドAPIはリクエストパラメータを適切バリデーションしましょう。

バックエンドAPIとWebフロントエンドは切り離すべきか

WebフロントエンドはバックエンドAPIに置いています。物理的に同じサーバーの同じアプリケーションで動作しています。/GET することで、WebフロントエンドのJavaScriptを取得する仕組みです。
バックエンドAPIとWebフロントエンド用のJavaScriptファイルは同じアプリケーション上に置いています。
バックエンドAPIとWebフロントエンドはプロジェクト自体を切り離してしまって、別々のサーバで動作させるべきかなと思います。

以下の理由があります。

  1. バックエンドAPIの開発とWebフロントエンドの開発を分けることができる。別々のリポジトリで管理することでプロジェクト全体の見通しが良くなります。
  2. バックエンドAPIとWebフロントエンドを別々にリリースできる。Webフロントエンドだけに変更があった場合でも、バックエンドAPIに不必要な再起動が発生することです。
  3. Webフロントエンドのレスポンスタイムを短くできるはず。Webフロントエンドはただの静的ファイルなので、ApacheやNGINXなどを利用するようにした方が速度は出ると思います。

終わりに

同じような構成でアプリケーションを作る場合は上記についてどのように設計すればいいか考えてみたほうがいいかもしれません。

15
12
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
15
12

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?