前后端跨域问题
前后端对接的时候,很容易出现跨域问题。从前端和后端都可以解决
前端
这是典型的跨域(CORS)问题。当浏览器从一个源(Origin)请求资源时,如果目标资源不在同一个源,就会触发 CORS 策略。
解决方案
方案一:在 Spring Boot 中添加 CORS 配置
创建一个 CORS 配置类:
package com.lanke.config; |
方案二:使用注解(适用于特定接口)
在需要跨域的控制器类或方法上添加 @CrossOrigin
注解:
|
关键配置说明
配置项 | 说明 |
---|---|
allowedOrigins | 允许的前端源(如 http://localhost:3000 ),支持 * 表示所有源 |
allowedMethods | 允许的 HTTP 方法(如 GET , POST ) |
allowedHeaders | 允许的请求头(如 Content-Type , Authorization ) |
allowCredentials | 是否允许携带 Cookie,设为 true 时 allowedOrigins 不能为 * |
maxAge | 预检请求(OPTIONS)的缓存时间,单位秒 |
前端请求验证
确保前端在请求中正确设置跨域相关的头信息(例如携带 Authorization
):
// JavaScript 示例(Axios) |
常见问题
预检请求(OPTIONS):
- 浏览器会先发送
OPTIONS
请求进行预检,确保后端正确响应200 OK
并包含Access-Control-Allow-*
头。 - 如果
OPTIONS
请求失败,检查后端是否拦截了该方法。
- 浏览器会先发送
携带 Cookie:
- 若需携带 Cookie,需同时设置
allowCredentials: true
和allowedOrigins
为具体源(不能为*
)。
- 若需携带 Cookie,需同时设置
路径匹配:
- 确保
addMapping("/**")
覆盖所有需要跨域的接口路径。
- 确保
前端与后端的联系
前端到底是怎么访问到后端 api 呢?
主要是依靠我们的 vite.config.ts
中的配置
server: { |
我们通过代理配置,将有 /api
有关的链接都拼接成后端的地址,这样我们就能访问成功了。
所以你可以在后端统一使用前缀 /api
也可以自己在前端,把各个接口都进行代理
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来源 Lanke!
评论