您的位置:首页 > 编程语言 > Java开发

ajax+springmvc实现跨域请求

2017-08-11 10:38 423 查看

ajax跨域请求(spring框架4.2版本后)

1. 错误信息

jquery-3.1.1.min.js:4 XMLHttpRequest cannot load http://127.0.0.1:8080/user/login.action. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:8080' is therefore not allowed access.

2. 解决办法

1. 方法一:@CrossOrigin注解
即在Controller控制器中,在Controller注解上方添加@CrossOrigin注解。
@CrossOrigin(origins = {"*"}, maxAge = 3600)
public class UserController {}

官网:www.fhadmin.org也可以在Controller控制器中的每个方法中分别添加@CrossOrigin注解。
@CrossOrigin(origins = {"*"}, maxAge = 3600)
public String login(String username, String password) throws Exception {}

假如添加之后还是出现了跨域问题,需要给映射路径中配置请求方法(method)
@RequestMapping(value = "user", method = {RequestMethod.POST})
@CrossOrigin(origins = {"*"}, maxAge = 3600) public class UserController {}

2. 方法二:CORS全局配置
基于xml的配置,在springmvc.xml中配置
<!-- 跨域请求 -->
<mvc:cors>
<mvc:mapping path="/user/*"/>
</mvc:cors>

官网:www.fhadmin.org 可以进行详细的配置
<mvc:cors>
<mvc:mapping path="/api/**"
allowed-origins="http://domain1.com, http://domain2.com" allowed-methods="GET, PUT"
allowed-headers="header1, header2, header3"
exposed-headers="header1, header2" allow-credentials="false"
max-age="123" />
<mvc:mapping path="/resources/**"
allowed-origins="http://domain1.com" />
</mvc:cors>

假如出现"通配符的匹配很全面, 但无法找到元素 'mvc:cors' 的声明。"这样的错误。
解决办法:
查看文件上边beans中xsd文件引入的版本是不是不对。

如下所示: http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd 
引入的xsd版本为3.0,而mvc:cors是4.2版本的功能。
因此,只需要将xsd版本更新就行。 http://www.springframework.org/schema/mvc/spring-mvc.xsd 或者设置成4.2以上的。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息