• 解决vue项目中前后端交互的跨域问题、nginx代理配置


    最近新接了一个项目,需要自己写一个小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中加入这两行代码

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

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

    2.解决跨域问题

    首先在config下的index.js文件中添加代码:

    1. proxyTable: {
    2. '/api': {
    3. target: 'http://192.168.0.79:2022',
    4. changeOrigin: true,
    5. pathRewrite: {
    6. '^/api': ''
    7. },
    8. onProxyReq: function (proxyReq, req, res) {
    9. // 实在不知道代理后的路径,可以在这里打印出出来看看2
    10. console.log('原路径1:' + req.originalUrl, '代理路径1:' + req.path)
    11. }
    12. }
    13. },

    然后需要在main.js中添加:

    axios.defaults.baseURL = '/api' 

    接着配置nginx代理(conf/nginx.conf):

    1. server {
    2. # 监听端口
    3. listen 8080;
    4. # 监听域名
    5. server_name localhost;
    6. #charset koi8-r;
    7. #access_log logs/host.access.log main;
    8. #请求头信息
    9. proxy_set_header X-Forwarded-Host $host;
    10. proxy_set_header X-Forwarded-Server $host;
    11. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    12. proxy_set_header Host $host;
    13. location /api {
    14. # 代理的地址
    15. proxy_pass http://192.168.0.79:2022/api;
    16. proxy_connect_timeout 600;
    17. proxy_read_timeout 600;
    18. }

    然后问题就成功解决啦 

     

  • 相关阅读:
    QT 6.5下载安装及配置教程
    Data-Free Learning of Student Networks论文阅读+代码解析
    三子棋小游戏思路及代码实现的详解
    【行为型模式】中介者模式
    《异 步》
    【VUE】vue程序设计----模仿网易严选
    封装形式,进化,DIP封装及键出方法
    虚拟机字节码执行引擎——动态类型语言支持
    Leetcode 完全平方数
    python将pdf转为txt
  • 原文地址:https://blog.csdn.net/weixin_44320032/article/details/126036444