解决AJAX session跨域失效

本文介绍了一种在使用AJAX进行跨域请求时遇到的Session丢失问题及其解决方案。该问题表现为前后端交互过程中,用于验证的Session在后端无法正确获取,导致验证失败。文章详细解释了解决方案的具体步骤,并指出在使用JQuery.get与JQuery.ajax时存在的差异。

1、想实现的功能是登录时有个验证码,这个验证码后台提供,然后放在session中,前台把用户输入的验证码通过AJAX发给后台,后台把session中的验证码取出来然后比较不同,一样则通过。

问题出现在校验环节,取出来的session属性值居然是空的,然后通过打印sessionID发现校验时和存储时的sessionID居然不是同一个,但是确实是一个回话,蛋疼啊~~~~

解决的过程不再赘述,现在上解决方法:

(1)在java的响应头处加上这个:

String origin = ((HttpServletRequest) request).getHeader("Origin");
System.out.println(origin);
response2.addHeader("Access-Control-Allow-Credentials", "true");
response2.setHeader("Access-Control-Allow-Origin", origin);
response2.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE");
response2.setHeader("Access-Control-Max-Age", "3600");
response2.setHeader("Access-Control-Allow-Headers", "Content-Type,Content-Length,Authorization,Access,X-Requested-With,my-http-header");

(2)AJAX

xhrFields: {
withCredentials: true
},
crossDomain: true,

有时候这样也不是万事大吉了,我就碰到了更蛋疼的,如果用JQuery.get去请求数据上述设置是无效的, 但是如果用JQuery.ajax就可以,查了下JQuery.get是JQury.ajax的简单实现,推测可能大概也许说不定时由于简化的过程去掉了 “没用”的东西。

转载于:https://www.cnblogs.com/xizhenghe/p/9008289.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值