解决ajax请求跨域问题

什么情况下会有跨域问题?
1.不同域名。
2.同一域名不同端口号。
3.同一域名不同协议。
4.域名和对应ip等。

采用CORS(跨来源资源共享)解决跨域问题。

web.xml添加如下配置
    <filter>
        <filter-name>cors</filter-name>
        <filter-class>com.rzg.dgztc.filter.CORSFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>cors</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
添加CORSFilter 类
public class CORSFilter implements Filter{

    @Override
    public void init(FilterConfig filterConfig) throws ServletException {

    }

    @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");
        response.setHeader("Access-Control-Max-Age", "3600");
        //访问请求头
        response.addHeader("Access-Control-Allow-Headers", "accessToken, deviceId, authType, Origin, X-Requested-With, Content-Type, Accept");
        chain.doFilter(req, res);

    }

    @Override
    public void destroy() {

    }

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
跨域问题是由浏览器的同源策略(Same-Origin Policy)所引起的。同源策略是浏览器的一种安全策略,它限制了一个网页文档或脚本如何能够与其他来源的资源进行交互。同源是指协议、域名端口号都相同,只要有一个不同就算跨域。 在jQuery中,如果要进行跨域请求,可以使用以下两种方式: 1. JSONP JSONP(JSON with Padding)是一种跨域请求数据的方式,它利用了script标签不受同源策略限制的特性。具体实现步骤如下: (1)定义一个回调函数 ```javascript function callback(data) { console.log(data); } ``` (2)在请求URL中添加回调函数参数 ```javascript $.ajax({ url: 'http://example.com/data?callback=callback', dataType: 'jsonp', }); ``` (3)服务端返回数据时,将数据作为参数传递给回调函数 ```javascript callback({name: '张三', age: 18}); ``` 2. CORS CORS(Cross-Origin Resource Sharing)是一种跨域访问资源的方式,它需要服务器端支持。具体实现步骤如下: (1)在服务端设置响应头 ```javascript Access-Control-Allow-Origin: http://example.com Access-Control-Allow-Methods: GET, POST Access-Control-Allow-Headers: X-Requested-With, Content-Type ``` (2)在客户端发送请求时,设置withCredentials属性为true ```javascript $.ajax({ url: 'http://example.com/data', type: 'GET', xhrFields: { withCredentials: true }, success: function(data) { console.log(data); } }); ``` 需要注意的是,使用CORS方式发送请求时,需要浏览器支持XMLHttpRequest Level 2和CORS。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值