什么是跨域?
通俗来说,跨域按照我自己的想法来理解,是不同的域名之间的访问,就是跨域。不同浏览器,在对js文件进行解析是不同的,浏览器会默认阻止,所以
现在我来说下用java代码解决前端跨域问题。
用java代码解决前端跨域问题?
找到WEB-INF下面的web.xml文件,输入下面代码,在web.xml文件下面:
<!-- 解决跨域访问的问题 -->
<filter>
<filter-name>cors</filter-name>
<filter-class>com.mj.yiCardCountry.filter.controller.SimpleCORSFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>cors</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<session-config>
<session-timeout>10</session-timeout>
</session-config>
然后创建一个类,在service或者controller ,我是在controller中创建的,输入以下代码:
public class SimpleCORSFilter implements Filter{ public void init(FilterConfig filterConfig) throws ServletException {} public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {
HttpServletResponse response = (HttpServletResponse) res;
response.setHeader("Access-Control-Allow-Origin", "*");
response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE");
response.setHeader("Access-Control-Max-Age", "3628800");
response.setHeader("Access-Control-Allow-Headers", "x-requested-with,content-type");
chain.doFilter(req, res);
} public void destroy() {} }
然后,重新install下 重新运行下 试试。基本上是ok了。