部分转自:http://www.cnblogs.com/cielosun/p/6741307.html
1. 通过注解的方式允许跨域。验证过,OK
非常简单,我们可以在Controller类或其方法上加@CrossOrigin
注解,来使之支持跨域。
举例:
@CrossOrigin(origins = "*", maxAge = 3600)
@RestController
@RequestMapping("/User")
public class UserController {
}
其中origins为CrossOrigin的默认参数,即跨域来源,*即任何来源,也可以是其他域名。即可以以以下形式:
@CrossOrigin("http://test.com")
@CrossOrigin(origins="http://test.com",maxAge=3600)
该注解用于方法上,写法相同,处理时,SpringMVC会对类上标签和方法上标签进行合并。
2. 通过配置文件的方式允许跨域。验证时出现问题,未发现CorsFilter的配置项目。
在web.xml中添加如下配置:
<filter-mapping>
<filter-name>CorsFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
3.MVC 4.0以后,使用这个Filter即可让整个服务器全局允许跨域。验证,OK。
<mvc:cors>
<mvc:mapping path="/**" allowed-origins="*" allow-credentials="true" max-age="1800" allowed-methods="GET,POST,OPTIONS"/>
</mvc:cors>
4.使用Ajax的JSONP,现目前测试主要使用JQUERY
待续...