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:这里面也可以制定网址访问
阅读全文
1 0
- angularjs做跨域遇到的一些问题
- Angularjs 中遇到的一些问题
- angularjs 与 springmvc 遇到的一些问题
- 用angularjs遇到的一些问题及解决方案
- 学习angularjs遇到的问题
- 遇到的一些问题
- 遇到的一些问题
- 遇到的一些问题
- 遇到的一些问题
- 遇到的一些问题
- yide开发遇到的问题(angularjs)
- 使用angularjs ui-bootstrap遇到的问题
- angularjs 做修改页面遇到的问题
- angularjs $scope.$watch 遇到的问题
- 小丸子总结angularjs的一些问题
- 今天遇到的一些问题
- 自己遇到的一些问题
- 最近遇到的一些问题
- iOS系列开发-版本控制工具Git的使用
- vue2+webpack+express 简单入门:从前端到后台
- 极验(geetest)滑动验证码研究
- jsp页面显示空白的原因
- 关于信息抽取的整理总结(上)
- angularjs做跨域遇到的一些问题
- .NET程序内存分析工具CLRProfiler的使用(性能测试)
- 消除眼袋的小窍门
- string to int to double and int double to string
- Spark源码分析之分区器的作用
- Spring源码学习--BeanDefinitionHolder
- 用java发送邮件
- 治理“乱闯红灯”,黑科技让你无处(灯)可闯
- 一维的Haar小波变换