最近新接了一个项目,需要自己写一个小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解决跨域问题。

1.安装axios

在控制台npm install axios

在main.js中加入这两行代码

import axios from 'axios'
Vue.prototype.$axios = axios

大功告成,接下来就可以使用axios了。

2.解决跨域问题

首先在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)
        }
      }
    },

在vue-cli3的版本中,webpack的配置文件会被隐藏,所以我们找不到config文件夹,就只需要把地址配置到vue.config.js文件,配置内容如下:

module.exports = {
  devServer: {
    // 端口号
    port: 3000,
    // 配置不同的后台API地址
    proxy: {
      '/api': {
        target: 'http://192.168.0.84:2022',
        // ws: false,
        changeOrigin: true,
        pathRewrite: {
          '^/api': ''
        }
      }
    }
  }
}

然后需要在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;
		}

然后问题就成功解决啦 

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐