webpack开发环境处理跨域的方法就是配置
devServer
的proxy,在服务器接口的nginx根据域名有多个分发的时候,会报404
- 通用配置:
cinfig-index.js
(基于vue-cli 2.x)
dev: {
proxyTable: {
'/dev': {
target: "http://xxx.xxxxxx.xx", // 转发到的服务器的域名/IP
pathRewrite: {
"^/dev": "" // 重写path
},
}
},
原理:
webpack
使用的是http-proxy-middleware
的包,找到配置
data:image/s3,"s3://crabby-images/ab45e/ab45e192822bd62bfca5bc88eef59cd52383aad0" alt=""
进而去看
http-proxy
的源码,打印请求配置:
data:image/s3,"s3://crabby-images/97d68/97d689f436ddf4805d01942dd416dc6dcc50b84c" alt=""
看出:host
是请求的地址,但在headers里,hosth还是localhost:8082
,此时请求是报404的,所以去找服务端的错误日志
data:image/s3,"s3://crabby-images/68e74/68e743c75fae3f59bff27da10ef3e047adac6a9b" alt=""
nginx从请求头里找到的host为
localhost
,和转发的配置规则不一样,就走到默认的路径里去里,自然找不到资源
解决办法: changeOrigin: true
http-proxy
的源码里关于请求头的配置:
data:image/s3,"s3://crabby-images/dd33b/dd33be45c1d62cd3bbdb1128435648b6122f3843" alt=""
该项是需要配置的:config-index.js
dev: {
proxyTable: {
'/dev': {
target: "http://xxx.xxxxxx.xx", // 转发到的服务器的域名/IP
pathRewrite: {
"^/dev": "" // 重写path
},
changeOrigin: true // 配置请求头
}
},
再来看请求头信息:
data:image/s3,"s3://crabby-images/10ff8/10ff8501753ae21e0105e5cdf0636e2bcbf19687" alt=""
就改为配置的域名了。
这时候就请求通过了。
小结
其实还是http协议的内容,没有出现bug就会忽视细节。多巩固原理吧。
网友评论