关于Java跨域的总结

来源:互联网 发布:mac触摸板透明 编辑:程序博客网 时间:2024/06/07 03:01

关于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里面,所以开发的时候不得已需要跨域。