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