36
35

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.

[Angular] Angular CLIでプロキシを利用する

Last updated at Posted at 2017-07-31

フロントエンドからバックエンドに対して、同一ホストだがポートが異なる構成で疎通したいケースがある。
たとえば

  • フロントエンドが localhost:4200/
  • バックエンドが localhost:3000/

といったケースである。
Angular では 通常、こうしたケースだと CORS によるエラーが発生してしまうのだが、Angular では Angular CLI でプロキシ設定ファイルを用意することで対応できる。

この記事を実施した環境

  • Windows10 Home 64bit
  • node v8.2.1
  • npm v4.0.5
  • angular/cli v1.2.6
  • Angular v4.3.2

プロキシ設定ファイルの用意(proxy.conf.json)

次の例だとフロントエンドの 「/app」にリクエストがきた場合、バックエンドの「localhost:3000」にフォワードされる設定となる。

proxy.conf.json
{
  "/app": {
    "target": "http://localhost:3000",
    "pathRewrite": {"^/app": ""}
  }
}

package.json の編集

プロキシ設定ファイルを用意したら、それを使用してアプリケーションを起動する設定を package.json に記載する。
具体的には、次の「start」の内容を package.json の「scripts」の要素に記載する。

package.json
{
  "scripts": {
    "start": "ng serve --proxy-config proxy.conf.json"
  }
}

プロキシ設定を反映させてアプリケーションを起動

前項までの設定を終えたら、次のコマンドを実行することでプロキシ設定を反映させた状態でアプリケーションが起動する。

// プロキシ設定を反映させる場合
$ npm run start

プロキシ設定を反映させたくない場合

プロキシ設定を反映させたくない場合、直接 ng serve でアプリケーションを起動させれば良い。

// プロキシ設定を反映させたくない場合
$ ng serve

参考

36
35
1

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
36
35

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?