最近新接了一个项目,需要自己写一个小demo和后端联调,第一次用自己写的demo和后端联调,出现了问题。
问题:Access to XMLHttpRequest at ‘http://192.168.0.78:8080’ from origin ‘http://192.168.0.79:2022’ has been blocked by CORS policy: No ‘Access-Control-Allow-Origin’ header is present on the requested resource.
vue向后端发送请求时时,被浏览器CORS阻止。
跨域指浏览器不允许当前页面的所在的源去请求另一个源的数据。源指协议,端口,域名。只要这个3个中有一个不同就是跨域。
我们使用axios解决跨域问题。
在控制台npm install axios
在main.js中加入这两行代码
- import axios from 'axios'
- Vue.prototype.$axios = axios
大功告成,接下来就可以使用axios了。
首先在config下的index.js文件中添加代码:
- proxyTable: {
- '/api': {
- target: 'http://192.168.0.79:2022',
- changeOrigin: true,
- pathRewrite: {
- '^/api': ''
- },
- onProxyReq: function (proxyReq, req, res) {
- // 实在不知道代理后的路径,可以在这里打印出出来看看2
- console.log('原路径1:' + req.originalUrl, '代理路径1:' + req.path)
- }
- }
- },
然后需要在main.js中添加:
axios.defaults.baseURL = '/api'
接着配置nginx代理(conf/nginx.conf):
- server {
- # 监听端口
- listen 8080;
- # 监听域名
- server_name localhost;
-
- #charset koi8-r;
-
- #access_log logs/host.access.log main;
- #请求头信息
- proxy_set_header X-Forwarded-Host $host;
- proxy_set_header X-Forwarded-Server $host;
- proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
- proxy_set_header Host $host;
-
- location /api {
- # 代理的地址
- proxy_pass http://192.168.0.79:2022/api;
- proxy_connect_timeout 600;
- proxy_read_timeout 600;
- }
然后问题就成功解决啦