广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >解决vue项目中前后端交互的跨域问题、nginx代理配置方式
  • 382
分享到

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

2024-04-02 19:04:59 382人浏览 安东尼
摘要

目录Vue前后端交互的跨域问题、Nginx代理配置1.安装axiOS2.解决跨域问题前后端分离项目的跨域问题及解决跨域简述解决办法vue前后端交互的跨域问题、nginx代理配置 最近

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中加入这两行代码

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;
        }

然后问题就成功解决啦 

前后端分离项目的跨域问题及解决

跨域简述

1.问题描述

这里前端vue项目的端口号为9000,后端SpringBoot项目的端口号为8080

2.什么是跨域

当一个请求url的协议、域名、端口三者之间任意一个与当前页面url不同即为跨域

当前页面url被请求页面url是否跨域原因
http://www.demo.com/http://www.demo.com/index.html同源(协议、域名、端口号相同)
http://www.demo.com/https://www.demo.com/协议不同(http/https)
http://www.demo.com/http://www.study.com/主域名不同(demo/study)
http://www.demo.com/http://test.demo.com/子域名不同(www/test)
http://www.demo.com:8080/http://www.demo.com:8081/端口号不同(8080/8081)

3.出现跨域问题的原因

跨域问题是出于浏览器的同源策略限制。同源策略(Sameoriginpolicy)是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,则浏览器的正常功能可能都会受到影响。

可以说WEB是构建在同源策略基础之上的,浏览器只是针对同源策略的一种实现。

同源策略会阻止一个域的javascript脚本和另外一个域的内容进行交互。所谓同源(即指在同一个域)就是两个页面具有相同的协议(protocol),主机(host)和端口号(port)。

解决办法

1.第一种解决办法:后端配置跨域(spring boot设置方式)

第一步:在后端的WebmvcConfig配置类中进行配置

@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
    
    @Override
    public void addCorsMappings(CorsReGIStry registry) {
        // 允许跨域访问资源定义: /rest/ 所有资源
        registry.addMapping(GlobalConstant.REST_URL_PREFIX +"/**")
                // 只允许本地的指定端口访问
//                .allowedOrigins("http://localhost:8080");
//                // 允许发送Cookie
                .allowCredentials(true);
//                // 允许所有方法
//                .allowedMethods("GET", "POST", "PUT", "DELETE", "HEAD");
    }
}

第二步:在vue项目src目录下的http包中的config.js进行配置携带凭证(cookie)

注意:这里是因为我需要前端发送凭证(cookie)所以要配两步;如果不需要携带cookie,可以将第二步忽略,并且将第一步中的allowCredentials(true);注释掉。

2.第二种解决办法:前端配置代理(vue项目)

第一步:在config/index.js 文件,配置proxyTable

proxyTable: {
      '/api': {
        target: 'http://127.0.0.1:8080', //  请求后台的真实路径,这里是我本地启动的一个后台项目
        changeOrigin: true, //
        pathRewrite: {
          '^/api': '' // 重写路径
        }
      },
    },

第二步:在config/dev.env.js文件中加上一句

module.exports = merge(prodEnv, {
  node_ENV: '"development"',
  API: '"/api"' // 加入这一句
})

因为这里我配的是全局路径,所以还要在global.js里配置全局路径

export const baseUrl = process.env.API

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。 

--结束END--

本文标题: 解决vue项目中前后端交互的跨域问题、nginx代理配置方式

本文链接: https://www.lsjlt.com/news/167216.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作