解决Springboot+VUE项目部署出现的跨域问题

自己写了一个项目,写好了,发现不会部署,然后到处查资料,最终终于部署好自己写的系统,系统为前后端分离项目。需要分别部署在同一个服务器docker中,配置不同得端口隐射,部署得过程中主要是跨域问题,导致在前端部署得vue项目访问不了后端数据。下面先进行前端部署

1部署前端vue

1.1 开发环境下解决跨域问题

首先生产环境下解决跨域问题适用于开发环境,即在后端配置跨域问题可以解决!!
如果不配置后端的话,就配置下前端vue开发环境下解决跨域问题是用vue-cli作为代理解决的跨域问题,使用Webpack的开发服务器来进行代理配置,具体配置如下:
一·第一步

module.exports = {
  devServer: {
    proxy: {
       port: 8081,// vue运行端口号
       host: '0.0.0.0',
      '/api': {
        target: 'http://your-spring-boot-server:8080', // 后端Spring Boot项目地址
        changeOrigin: true,
        pathRewrite: {
          '^/api': ''
        }
      }
    }
  }
};

二·第二步

const http = axios.create({
        baseURL: '/api', // 以访问以api开头
        timeout: 10000,
    }
)

重启前端项目
注意:在生产环境中,为了解决跨域问题,你不能再使用Webpack的开发服务器来进行代理配置。代理配置只适用于开发环境。
Vue的代理配置是为了在开发环境中解决前后端分离开发时的跨域问题。当你在开发阶段使用npm run serve命令启动本地开发服务器时,Vue会根据vue.config.js中的代理配置,将特定请求代理到后端API服务,以解决跨域问题。这样,在开发阶段就可以顺利发起跨域请求,与后端API进行交互。但是,一旦将Vue项目打包部署到生产环境中,通过vue-cli-service build生成的静态资源文件会被部署在Web服务器中(例如Nginx、Apache等)。这时,Vue的代理配置将不再生效,因为所有的前端请求都会直接发送到部署的Web服务器,而不再通过vue.config.js中的代理配置。

1.2 生产环境下解决跨域问题

下面提供两种方法,任选其一即可
1.在Spring Boot应用的Controller类上添加**@CrossOrigin**注解:
注意:

  • springMVC的版本要在4.2或以上版本才支持@CrossOrigin
  • 非@CrossOrigin没有解决跨域请求问题,而是不正确的请求导致无法得到预期的响应,导致浏览器端提示跨域问题。
  • 在Controller注解上方添加@CrossOrigin注解后,仍然出现跨域问题,解决方案之一就是:在@RequestMapping注解中没有指定Get、Post方式,具体指定后,问题解决。其中@CrossOrigin中的2个参数:origins : 允许可访问的域列表
    maxAge:准备响应前的缓存持续的最大时间(以秒为单位)。可以配置在Controller上 也可以配置在方法上。

2.在Spring Boot中,你可以使用Spring Web提供的CORS支持来解决跨域问题。Spring Boot提供了配置选项来设置允许访问的域名、请求方法、请求头等。
在你的Spring Boot项目中,你需要添加一个CORS配置类来设置CORS头。


import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

@Configuration
public class CorsConfig implements WebMvcConfigurer {
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**") // 需要配置跨域的接口路径,可以使用通配符
            .allowedOrigins("http://ip地址:端口") // 允许访问的域名,可以使用通配符,如:*表示允许所有域名
            .allowedMethods("GET", "POST", "PUT", "DELETE") // 允许的请求方法
            .allowedHeaders("Content-Type") // 允许的请求头
            .allowCredentials(true); // 允许携带凭证,例如:cookies
    }
}

注意:配置类文件一定要写在启动类所在的包下,否则不生效。可以新建一个config包,在里面创建配置文件
在上面的示例中,我们创建了一个CorsConfig类,并实现了WebMvcConfigurer接口,然后在addCorsMappings方法中设置了CORS头。

  • “registry.addMapping(“/admin/**”)”:这里可以设置需要进行CORS配置的接口路径,/**通配符表示匹配所有路径,也可以根据实际情况设置具体的路径。
  • allowedOrigins(“http://localhost:8081”):这里设置允许访问的域名,可以使用通配符*表示允许所有域名。
  • allowedOrigins(“http://localhost:8081”):这里设置允许访问的域名,可以使用通配符*表示允许所有域名。
  • allowedHeaders(“Content-Type”):设置允许的请求头,这里只允许Content-Type头。
  • allowCredentials(true):设置允许携带凭证,例如:cookies。
    注意:在生产环境中,不要使用通配符 * 来允许所有域名访问API,这是不安全的做法。应该根据具体情况设置允许访问的域名。
    然后需要在创建axios实例或者使用axios时设置baseURL进行配置后端请求地址即可

注意: 这样配置完后前端不用配置vue.config.js文件了,vue.config.js配置的跨域代理只在生产环境下有效

// 创建一个 axios 实例
const http = axios.create({
        baseURL: 'http://你的ip:端口号/admin', 
        timeout: 10000,
    }
)

<think>好的,用户想知道如何将SpringBootVue组合的项目部署到生产环境。我需要结合提供的引用内容,整理出一个清晰的步骤指南。 首先,用户可能需要一个整体的流程,从打包到部署再到验证。我需要分步骤说明,每个部分需要涵盖SpringBootVue的处理方式。 关于SpringBoot部分,引用里提到使用mvn clean package打包,生成jar文件。然后通过nohup命令启动,同时指定日志输出。这部分需要注意Java环境的配置,比如安装JDK,设置环境变量,这在引用3中有详细步骤。需要提醒用户检查Java版本,并正确配置PATH。 然后是Vue项目部署。通常Vue会打包成静态文件,需要配置生产环境的环境变量,比如API的baseURL指向后端地址。打包后生成的dist文件夹需要放到Web服务器如Nginx中,或者和SpringBoot一起部署。但引用中没有提到Nginx的配置,可能需要补充静态资源处理和反向代理的设置。 生产环境配置方面,SpringBoot的application-prod.properties需要设置端口、数据库连接、开启压缩等。同时,安全配置如关闭调试信息、设置CORS也很重要。Vue部分则需要配置生产环境变量,确保API请求正确。 启动和停止脚本部分,引用4提到了使用nohup启动,并保存日志。停止时需要根据PID结束进程。需要详细说明如何编写启动脚本和停止脚本,以及如何获取进程ID。 验证部分,用户需要检查后端接口和前端页面是否正常,可能需要使用curl测试API,或者查看日志排查问题。引用2和4提到了浏览器访问验证,需要确保端口开放和防火墙设置正确。 最后,注意事项里要提到环境一致性、日志管理和备份策略,这些都是部署后维护的关键点。可能还需要补充一些常见问题解决方法,比如端口冲突、依赖缺失等。 现在需要确保所有步骤清晰,语言简洁,符合用户的需求。同时,按照系统指令正确使用LaTeX格式,比如$JAVA_HOME$这样的变量用行内公式,独立命令块用代码块。引用标注要自然,比如在打包步骤后添加[^2],环境配置引用[^4]等。 可能还需要生成相关问题,比如如何优化部署流程、如何处理问题、怎样配置HTTPS等,这些都可以作为后续的问题。</think>### SpringBoot + Vue 项目部署到生产环境分步指南 #### 一、环境准备 1. **服务器基础环境** - 安装JDK 1.8+并配置环境变量: ```bash # 解压JDK并设置路径(引用[^3]) tar -zxvf jdk-8u371-linux-x64.tar.gz -C /usr/local/ mv /usr/local/jdk1.8.0_371 /usr/local/java vi /etc/profile # 添加以下内容 ``` ```shell export JAVA_HOME=/usr/local/java export PATH=$JAVA_HOME/bin:$PATH ``` ```bash source /etc/profile java -version # 验证 ``` #### 二、项目打包 1. **SpringBoot后端打包** - 在项目根目录执行: ```bash mvn clean package # 生成target/*.jar(引用[^2]) ``` - 生成的JAR包路径示例:`target/vue-0.0.1-SNAPSHOT.jar` 2. **Vue前端打包** - 修改生产环境配置(`.env.production`): ```ini VUE_APP_API_BASE_URL=http://your-domain.com/api ``` - 执行构建: ```bash npm run build # 生成dist目录 ``` #### 三、部署架构 $$部署架构示意图$$ ``` 用户请求 -> Nginx(静态资源+反向代理) -> SpringBoot服务(JAR) ``` #### 四、服务端配置 1. **SpringBoot部署** - 上传JAR包至服务器(如`/home/java/`) - 启动命令(引用): ```bash nohup java -jar /home/java/vue-0.0.1-SNAPSHOT.jar \ > /home/java/logs/202408012log.txt 2>&1 & ``` - 停止服务: ```bash pid=$(ps -ef | grep vue-0.0.1 | grep -v grep | awk '{print $2}') kill -9 $pid ``` 2. **Vue静态资源部署** - 配置Nginx(示例配置): ```nginx server { listen 80; server_name your-domain.com; location / { root /home/web/dist; try_files $uri $uri/ /index.html; } location /api { proxy_pass http://localhost:8080; proxy_set_header Host $host; } } ``` #### 五、生产环境配置 1. **SpringBoot配置** ```properties # application-prod.properties server.port=8080 spring.datasource.url=jdbc:mysql://localhost:3306/prod_db?useSSL=false spring.jpa.hibernate.ddl-auto=validate server.compression.enabled=true # 启用响应压缩(引用[^4]) ``` 2. **安全增强** - 关闭`actuator`端点(如非必要) - 配置CORS白名单 - 启用HTTPS加密 #### 六、验证流程 1. **后端验证** ```bash curl http://localhost:8080/api/health-check ``` 预期返回:`{"status":"UP"}` 2. **前端验证** - 浏览器访问`http://your-domain.com`,检查页面加载与接口调用 #### 七、注意事项 1. **环境一致性**:确保测试/生产环境的数据库版本、依赖库版本一致 2. **日志管理**:定期归档`/home/java/logs`目录下的日志文件[^4] 3. **监控配置**:建议添加服务存活监控(如`systemd`托管服务)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值