Alan 068bb4001d docs: add deprecation and pr note
Docs are deprecated in favor of the the new pages in AIO which are WIP.
2019-01-09 09:14:13 -08:00

189 lines
5.0 KiB
Markdown

**Documentation below is for CLI version 6 and we no longer accept PRs to improve this. For version 7 see [here](https://angular.io/guide/build#using-corporate-proxy)**.
# Proxy To Backend
Using the [proxying support](https://webpack.js.org/configuration/dev-server/#devserver-proxy) in webpack's dev server we can highjack certain URLs and send them to a backend server.
We do this by passing a file to `--proxy-config`
Say we have a server running on `http://localhost:3000/api` and we want all calls to `http://localhost:4200/api` to go to that server.
We create a file next to our project's `package.json` called `proxy.conf.json` with the content
```json
{
"/api": {
"target": "http://localhost:3000",
"secure": false
}
}
```
You can read more about what options are available [here](https://webpack.js.org/configuration/dev-server/#devserver-proxy).
We can then add the `proxyConfig` option to the serve target:
```json
"architect": {
"serve": {
"builder": "@angular-devkit/build-angular:dev-server",
"options": {
"browserTarget": "your-application-name:build",
"proxyConfig": "proxy.conf.json"
},
```
Now in order to run our dev server with our proxy config we can call `ng serve`.
**After each edit to the proxy.conf.json file remember to relaunch the `ng serve` process to make your changes effective.**
### Rewriting the URL path
One option that comes up a lot is rewriting the URL path for the proxy. This is supported by the `pathRewrite` option.
Say we have a server running on `http://localhost:3000` and we want all calls to `http://localhost:4200/api` to go to that server.
In our `proxy.conf.json` file, we add the following content
```json
{
"/api": {
"target": "http://localhost:3000",
"secure": false,
"pathRewrite": {
"^/api": ""
}
}
}
```
If you need to access a backend that is not on localhost, you will need to add the `changeOrigin` option as follows:
```json
{
"/api": {
"target": "http://npmjs.org",
"secure": false,
"pathRewrite": {
"^/api": ""
},
"changeOrigin": true
}
}
```
To help debug whether or not your proxy is working properly, you can also add the `logLevel` option as follows:
```json
{
"/api": {
"target": "http://localhost:3000",
"secure": false,
"pathRewrite": {
"^/api": ""
},
"logLevel": "debug"
}
}
```
Possible options for `logLevel` include `debug`, `info`, `warn`, `error`, and `silent` (default is `info`)
### Multiple entries
If you need to proxy multiple entries to the same target define the configuration in `proxy.conf.js` instead of `proxy.conf.json` e.g.
```js
const PROXY_CONFIG = [
{
context: [
"/my",
"/many",
"/endpoints",
"/i",
"/need",
"/to",
"/proxy"
],
target: "http://localhost:3000",
secure: false
}
]
module.exports = PROXY_CONFIG;
```
Make sure to point to the right file (`.js` instead of `.json`):
```json
"architect": {
"serve": {
"builder": "@angular-devkit/build-angular:dev-server",
"options": {
"browserTarget": "your-application-name:build",
"proxyConfig": "proxy.conf.js"
},
```
### Bypass the Proxy
If you need to optionally bypass the proxy, or dynamically change the request before it's sent, define the configuration in proxy.conf.js e.g.
```js
const PROXY_CONFIG = {
"/api/proxy": {
"target": "http://localhost:3000",
"secure": false,
"bypass": function (req, res, proxyOptions) {
if (req.headers.accept.indexOf("html") !== -1) {
console.log("Skipping proxy for browser request.");
return "/index.html";
}
req.headers["X-Custom-Header"] = "yes";
}
}
}
module.exports = PROXY_CONFIG;
```
### Using corporate proxy
If you work behind a corporate proxy, the regular configuration will not work if you try to proxy
calls to any URL outside your local network.
In this case, you can configure the backend proxy to redirect calls through your corporate
proxy using an agent:
```bash
npm install --save-dev https-proxy-agent
```
Then instead of using a `proxy.conf.json` file, we create a file called `proxy.conf.js` with
the following content:
```js
var HttpsProxyAgent = require('https-proxy-agent');
var proxyConfig = [{
context: '/api',
target: 'http://your-remote-server.com:3000',
secure: false
}];
function setupForCorporateProxy(proxyConfig) {
var proxyServer = process.env.http_proxy || process.env.HTTP_PROXY;
if (proxyServer) {
var agent = new HttpsProxyAgent(proxyServer);
console.log('Using corporate proxy server: ' + proxyServer);
proxyConfig.forEach(function(entry) {
entry.agent = agent;
});
}
return proxyConfig;
}
module.exports = setupForCorporateProxy(proxyConfig);
```
This way if you have a `http_proxy` or `HTTP_PROXY` environment variable defined, an agent will automatically be added to pass calls through your corporate proxy when running `npm start`.