关于Java跨域的总结

xiaoxiao2021-02-28  52

关于Java跨域的总结

使用crossdomain.xml 文件实现跨域(flex)配置filter过滤器 配置springMVC

* 1. 首先使用用crossdomain.xml文件实现跨域 *

<?xml version="1.0"?> <cross-domain-policy> <allow-access-from domain="localhost:8080" /> </cross-domain-policy>

表示允许来源为本地8080端口的请求,因为Tomcat默认是访问的webapp下面的root目录,所以要将这个文件放到该目录下。。

* 2. 使用过滤器实现 *

<filter> <display-name>AcrossDomainFilter</display-name> <filter-name>AcrossDomainFilter</filter-name> <filter-class>com.test.demo.filter.AcrossDomainFilter</filter-class> </filter> <filter-mapping> <filter-name>AcrossDomainFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>

Java代码为:

/** * @see Filter#doFilter(ServletRequest, ServletResponse, FilterChain) * 配置跨域过滤器 * */ public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpServletRequest httpRequest = (HttpServletRequest) request; HttpServletResponse httpResponse = (HttpServletResponse) response; httpResponse.addHeader("Access-Control-Allow-Origin", "*"); httpResponse.addHeader("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE"); httpResponse.addHeader("Access-Control-Allow-Headers", "Content-Type"); httpResponse.addHeader("Access-Control-Max-Age", "1800");//30 min chain.doFilter(httpRequest, httpResponse); }

* 3. 使用springMVC配置文件 *

<mvc:cors> <mvc:mapping path="/**" allowed-origins="*" allow-credentials="true" max-age="1800" allowed-methods="GET,POST,OPTIONS"/> </mvc:cors>

因为使用了springMVC 所以也可以利用它来配置跨域。因为这个项目前端是跑在node里面,所以开发的时候不得已需要跨域。

转载请注明原文地址: https://www.6miu.com/read-35841.html

最新回复(0)