早些时候咱们作了一个项目,用的是先后端分离,前端vue,后端提供功能接口,而后两个部署在不一样的域名下,后端接口开放了跨域,方便前端本地开发调试。前端项目域名为www.a.com
,后端的接口域名为 www.b.com
,上线后也没问题,一切都美滋滋的。直到有一天,用户反馈过来有一个页面一些数据出现的太慢了。。html
而后咱们各类优化,前端缓存、数据库索引等等,快了那么一点,最后想能不能再快点,由于一开始用了开放跨域,且接口的请求方法为post,因此是复杂请求,会先发送一个options请求探探路,每一个接口都会发这个,消耗的时间都有几百毫秒,这样时间就捉急了,那么如何解决这个问题呢~前端
为何会跨域、复杂请求、nginx的使用不在本文范围~vue
目录结构图以下java
html ├── 50x.html ├── a │ └── index.html ├── b │ ├── apis │ │ └── login.json │ └── login.json └── index.html
b/login.json的内容为`{node
"location": "我是b站点/login"
}`
b/apis/login.json的内容为`{nginx
"location":"我是b站点/apis/login"
}`
b/apis/login.json存在的意义是验错,没有的的话访问是404,可是须要知道访问到哪啦数据库
修改前端项目www.a.com
中的请求接口为www.a.com/apis/login
,真正的接口地址为www.b.com/login
,若是请求www.a.com/apis/login
能获取json数据,则不会进行跨域(前端项目和接口在同一域名下),也不会发options请求json
全部/apis/打头的接口,所有去请求www.b.com
后端
nginx配置以下图api
server { listen 80; server_name www.a.com; access_log logs/test.access.log; # 匹配以/apis/开头的请求 location ^~ /apis/ { proxy_pass http://www.b.com; } location / { root html/a; index index.html index.htm; } # error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } }
proxy_pass 经常使用在反向代理,好比nginx代理node服务,java服务
curl www.a.com/apis/login.json
结果为
{ "location":"我是b站点/apis/login" }
结果是不对的(观察下上文给出的文件夹下,还有个apis/login.json
),心理的预期www.a.com/apis/login.json
是要访问到www.b.com/login.json,应该是b文件夹下的login.json,内容为
`{
"location": "我是b站点/login"
}`
server { listen 80; server_name www.a.com; access_log logs/test.access.log; # 匹配以/apis/开头的请求 location ^~ /apis/ { proxy_pass http://www.b.com/; #注意域名后有一个/ } location / { root html/a; index index.html index.htm; } # error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } }
没错就是proxy_pass后面的地址加一个/
www.a.com/apis/login.json
会获得www.b.com/login.json
(符合预期的),使用b文件夹做为/目录来访问www.b.com/apis/login.json
会获得www.b.com/apis/login.json
(不符合预期),使用b文件下的apis做为根目录进行访问最终的效果为
{ "location": "我是b站点/login" }