Vue与Springboot跨域问题以及nginx部署

一、首先解决本地开发环境的跨域

1. springboot配置全局跨域

 // 全局跨域,添加所有的mapping,methods,origins等
package com.zty.springboot01login.Config;

import org.springframework.context.annotation.Configuration;
import org.springframework.http.HttpHeaders;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurationSupport;

@Configuration
@EnableWebMvc
public class CORSConfiguration extends WebMvcConfigurationSupport {
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**")
                .allowedMethods("*")
                .allowedOrigins("*")
                .allowedHeaders("*").
                allowCredentials(true).
                exposedHeaders(HttpHeaders.SET_COOKIE).maxAge(3600L);
                super.addCorsMappings(registry);
    }
}

2. vue配置代理

在config/index.js中配置代理,让vue的所有http请求都跨域,在文件中写一个proxyObj,http所有请求都指向后端的端口,此处为8800

let proxyObj = {};
proxyObj['/ws'] = {
  ws: true,
  target: "ws://localhost:8800"
};
proxyObj['/'] = {
  ws: false,
  target: 'http://localhost:8800',
  changeOrigin: true,
  pathRewrite: {
    '^/': ''
  }
}

更改dev proxyTable

3. 开发环境测试

我的开发环境为windows10,为了和ubuntu环境一致,也使用nginx

  1. 先分别启动vue dev和springboot,测试两边能够跨域
  2. 然后启动vue打包dist,放到ngixn的文件夹下,启动nginx,测试能否与后端跨域
  3. 配置nginx的config如下,所有的api请求都跨域
  server {
        listen       8081;
        server_name  localhost;
        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html\dist;
            index  index.html index.htm;
        }
        
        location /api/ {
			proxy_redirect off;
			proxy_set_header Host $host;
			proxy_set_header X-Real-IP $remote_addr;
			proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
			rewrite /api/(.*) /$1 break;
			# 后端服务地址
			proxy_pass http://localhost:8800;
        }

二、 解决ubuntu部署nginx的跨域

  1. 打包vue为dist放到ubuntu
  2. 打包idea下的项目,使用maven的package打包为jar,也放到ubuntu
  3. 配置nginx/default,把root改为dist目录,然后添加一个localtion
        location /api/ {
			proxy_redirect off;
			proxy_set_header Host $host;
			proxy_set_header X-Real-IP $remote_addr;
			proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
			rewrite /api/(.*) /$1 break;
			# 后端服务地址
			proxy_pass http://localhost:8800;
        }
  1. 启动nginx,通过ip和端口访问即可
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现Vue前端与Spring Boot后端的跨域通信,可以使用Nginx作为代理服务器来解决跨域问题。以下是一个简单的Nginx代理配置示例: 首先,确保你已经正确安装和配置了Nginx。然后,在Nginx的配置文件中添加以下内容: ``` http { server { listen 80; server_name example.com; # 静态文件目录 location / { root /path/to/frontend; try_files $uri $uri/ /index.html; } # API代理 location /api/ { proxy_pass http://backend_server; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } } # 后端服务器配置 upstream backend_server { server backend_server_ip:backend_server_port; } } ``` 在这个示例中,假设前端文件存放在`/path/to/frontend`目录下,后端服务器的IP地址为`backend_server_ip`,端口为`backend_server_port`。 配置中的`location /`指定了前端静态文件的目录,并使用`try_files`指令将所有请求都重定向到`index.html`,以支持前端路由。 配置中的`location /api/`指定了后端API的代理,并通过`proxy_pass`将请求转发到后端服务器。`proxy_set_header`指令用于设置请求头信息,以便后端服务器能够获取到正确的客户端信息。 请根据你的实际情况修改示例中的路径、后端服务器地址和端口,并将上述配置添加到Nginx的配置文件中。重启Nginx后,Vue前端和Spring Boot后端之间的跨域通信应该可以正常工作了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值