angularjs做跨域遇到的一些问题

来源:互联网 发布:数据仓库与数据库区别 编辑:程序博客网 时间:2024/05/01 20:20

最近做angular跨域,发现很多问题,也搜索了很多方法都试过,还好最终都弄出来了,

首先jsonp 这个是可以做跨域的,但是只支持get请求,而且要固定返回callback,所以返回类型只能是String,测试可以,但是不考虑,

Nginx当然肯定是可以的,但是这不属于真正的跨域。

最后我直接在后台写了个filter 搞定。

直接上代码

package com.cdy.filter;import java.io.IOException;import java.io.PrintWriter;import java.util.HashMap;import java.util.Map;import javax.servlet.Filter;import javax.servlet.FilterChain;import javax.servlet.FilterConfig;import javax.servlet.ServletException;import javax.servlet.ServletRequest;import javax.servlet.ServletResponse;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import net.sf.json.JSONArray;public class SimpleCORSFilter implements Filter{        @Override      public void destroy() {                }        @Override      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");  // 允许请求的HTTP Method            response.setHeader("Access-Control-Max-Age", "3600");   // 授权的时间            response.setHeader("Access-Control-Allow-Headers", "Origin, Accept, X-Requested-With, Content-Type, Access-Control-Request-Method, Access-Control-Request-Headers"); // 控制哪些header能发送真正的请求               response.setHeader("Access-Control-Allow-Credentials", "true");// 控制是否开启与Ajax的Cookie提交方式            chain.doFilter(req, res);  */        HttpServletResponse response = (HttpServletResponse) res;        HttpServletRequest request = (HttpServletRequest)req;        System.out.println("Origin:"+request.getHeader("Origin"));        response.setHeader("Access-Control-Allow-Origin", request.getHeader("Origin"));        response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE");        response.setHeader("Access-Control-Max-Age", "3600");        response.setHeader("Access-Control-Allow-Headers", "x-requested-with, ws_auth_token");        response.setHeader("Access-Control-Allow-Credentials","true"); //是否支持cookie跨域        String token = request.getHeader("ws_auth_token");        if(token==null){        token ="admin";        }        System.out.println(request.getMethod());        try{        System.out.println(request.getSession().getId());        chain.doFilter(req, res);        }catch(Exception e){        Map<String,Object> map = new HashMap<String,Object>();    map.put("code", "900");    map.put("message", e.getMessage());    //map.put("data", Utils.getErrorInfoFromException(e));    String msg = JSONArray.fromObject(map).toString();        PrintWriter out= response.getWriter();    out.write(msg);    out.flush();    out.close();    response.setStatus(900);        }              }        @Override      public void init(FilterConfig arg0) throws ServletException {                }    } 

之前试了很多方法都不行,主要是这个过滤器设置有问题,参照这个一般不会有问题,问题解决了,特记录下。ps:这里面也可以制定网址访问

原创粉丝点击