SpringBoot 跨域问题

什么是跨域问题,例如你的前端程序和后端程序不在一个域名或端口上,这时你可以使用@CrossOrigin 注解来允许前端应用程序与后端应用程序进行通信。

@CrossOrigin用于在 Spring Boot 应用程序中启用跨域资源共享(CORS),它可以应用于控制器类或方法上,并指定允许跨域请求的来源、方法和其他选项

CORS 是一种安全机制,用于限制 Web 应用程序中的跨站点 HTTP 请求。默认情况下,浏览器只允许同源请求,即只有来自相同协议、主机和端口的请求才能成功发送。如果尝试从不同源头发出请求,则会收到一个错误,这是浏览器实现的安全功能。

使用 @CrossOrigin 注解可以使 Spring Boot 应用程序接受跨域请求,从而允许来自其他域的客户端访问应用程序的资源。例如,如果你的前端应用程序在一个不同的域名或端口上运行,那么你可以使用 @CrossOrigin 注解来允许前端应用程序与后端应用程序进行通信。

以下是 @CrossOrigin 注解的一些常见属性:
  • origins:指定允许跨域请求的来源。可以指定一个或多个来源,例如 @CrossOrigin(origins = "http://example.com") 或者 @CrossOrigin(origins = {"http://example.com", "http://localhost:8080"})
  • methods:指定允许的 HTTP 方法。默认情况下,允许所有方法(GET、POST、PUT 等)。可以使用 @CrossOrigin(methods = RequestMethod.GET) 或者 @CrossOrigin(methods = {RequestMethod.GET, RequestMethod.POST}) 来指定特定的方法。
  • allowedHeaders:指定允许的 HTTP 头。默认情况下,允许所有头。可以使用 @CrossOrigin(allowedHeaders = "Authorization") 或者 @CrossOrigin(allowedHeaders = {"Authorization", "Content-Type"}) 来指定特定的头。
  • exposedHeaders:指定允许客户端访问的响应头。默认情况下,不允许访问任何响应头。可以使用 @CrossOrigin(exposedHeaders = "Authorization") 或者 @CrossOrigin(exposedHeaders = {"Authorization", "Content-Disposition"}) 来指定特定的响应头。
  • allowCredentials:指定是否允许发送凭据(如 cookie 和 HTTP 认证信息)。默认情况下,不允许发送凭据。可以使用 @CrossOrigin(allowCredentials = "true") 来启用凭据发送。
当浏览器发起跨域请求时,如果服务器没有正确配置跨域资源共享(CORS),浏览器会拒绝该请求,并在开发者工具的控制台中报告以下错误之一
  1. “Access to XMLHttpRequest at ‘http://example.com’ from origin ‘http://localhost:8080’ has been blocked by CORS policy: No ‘Access-Control-Allow-Origin’ header is present on the requested resource.”:这是最常见的跨域错误,表示服务器未返回正确的 Access-Control-Allow-Origin 响应头,允许来自特定源的请求访问资源。
  2. “Access to XMLHttpRequest at ‘http://example.com’ from origin ‘http://localhost:8080’ has been blocked by CORS policy: Response to preflight request doesn’t pass access control check: It does not have HTTP ok status.”:这个错误表示服务器未正确处理预检请求(preflight request)。预检请求是一种 OPTIONS 请求,用于检查实际请求是否安全和允许。服务器需要正确响应预检请求并返回正确的 CORS 头。
  3. “Access to XMLHttpRequest at ‘http://example.com’ from origin ‘http://localhost:8080’ has been blocked by CORS policy: Method GET is not allowed by Access-Control-Allow-Methods in preflight response.”:这个错误表示服务器未正确配置 Access-Control-Allow-Methods 响应头,指定允许的 HTTP 方法。
  4. “Access to XMLHttpRequest at ‘http://example.com’ from origin ‘http://localhost:8080’ has been blocked by CORS policy: The ‘Access-Control-Allow-Origin’ value ‘http://example.com’ only allows the ‘https’ protocol.”:这个错误表示服务器配置的 Access-Control-Allow-Origin 响应头只允许特定的协议(例如 HTTPS),而请求使用了不同的协议。
  5. “Failed to load resource: net::ERR_NAME_NOT_RESOLVED”:这个错误表示浏览器无法解析请求的域名。可能是因为域名不存在、DNS 配置错误或网络连接问题。
下面用几个例子简单描述下@CrossOrigin注解的使用场景
// 允许所有来源的请求
@CrossOrigin
@RestController
public class MyController {
    // ...
}
// 指定允许特定来源的请求
@CrossOrigin(origins = "http://example.com")
@RestController
public class MyController {
    // ...
}
// 指定允许多个来源的请求
@CrossOrigin(origins = {"http://example.com", "http://localhost:8080"})
@RestController
public class MyController {
    // ...
}

// 指定允许特定方法的请求
@CrossOrigin(methods = RequestMethod.GET)
@RestController
public class MyController {
    // ...
}
// 指定允许多个方法的请求
@CrossOrigin(methods = {RequestMethod.GET, RequestMethod.POST})
@RestController
public class MyController {
    // ...
}

// 指定允许特定头的请求
@CrossOrigin(allowedHeaders = "Authorization")
@RestController
public class MyController {
    // ...
}
// 指定允许多个头的请求
@CrossOrigin(allowedHeaders = {"Authorization", "Content-Type"})
@RestController
public class MyController {
    // ...
}

// 指定允许客户端访问的响应头
@CrossOrigin(exposedHeaders = "Authorization")
@RestController
public class MyController {
    // ...
}
// 指定允许多个响应头
@CrossOrigin(exposedHeaders = {"Authorization", "Content-Disposition"})
@RestController
public class MyController {
    // ...
}

// 启用发送凭据(如 cookie 和 HTTP 认证信息)
@CrossOrigin(allowCredentials = "true")
@RestController
public class MyController {
    // ...
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring Boot跨域问题可以通过配置来解决。下面是一种常见的解决方法: 在 Spring Boot 项目中,可以使用 `@CrossOrigin` 注解来处理跨域问题。这个注解可以直接添加在 Controller 类或者方法上,用于指定允许跨域的源。 示例代码如下: ```java @RestController @CrossOrigin(origins = "http://example.com") public class MyController { @GetMapping("/api/data") public String getData() { // 处理请求 return "data"; } } ``` 在上述示例中,`@CrossOrigin(origins = "http://example.com")` 指定了允许跨域访问的源,即来自 http://example.com 的请求可以跨域访问该接口。 如果需要允许多个源进行跨域访问,可以使用数组形式指定多个源,如: ```java @CrossOrigin(origins = {"http://example.com", "http://another-domain.com"}) ``` 此外,还可以通过全局配置方式解决跨域问题。在 Spring Boot 项目的配置类中添加如下配置: ```java @Configuration public class CorsConfig implements WebMvcConfigurer { @Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping("/**") .allowedOrigins("http://example.com") .allowedMethods("GET", "POST", "PUT", "DELETE") .allowedHeaders("*") .allowCredentials(true) .maxAge(3600); } } ``` 上述配置中,`allowedOrigins` 指定允许跨域访问的源,`allowedMethods` 指定允许的请求方法,`allowedHeaders` 指定允许的请求头,`allowCredentials` 表示是否允许发送身份凭证(如 cookie),`maxAge` 指定预检请求的有效期。 这是一种常见的解决 Spring Boot 跨域问题的方法,你可以根据实际情况选择适合的方式来解决跨域问题

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

95的猪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值