在项目里面遇到这么一个问题,当点击登录后把用户信息写进session。但是问题就出现在ajax提交以后,并没有实时的写进sessio。所以导致无法在前端用<s:if test="#session.users!=null">判断是否登录成功。于是上网找到了相关答案。
以下为引用:
仍定为跨域问题。
跨域本是出于安全考虑:同源策略即JavaScript或者Cookie只能访问同域下的内容;也因为这个才会出现好多莫名其妙的问题。
提起跨域就能想到CORS(跨域资源共享,cross-origin resource sharing)可以让AJAX实现跨域访问。CORS允许一个域上的网络应用向另一个域提交跨域AJAX请求。
首先前端在ajax请求时添加
xhrFields: {
withCredentials: true
},
withCredentials值为真则是允许跨域名请求;
源码如下
$.ajax({
url:$rootScope.interfacePath+"checkpiccode/",
dataType:"json",
xhrFields: {
withCredentials: true
},
data:{mobile: mobile,code:tpyzm},
type:"get",
success:function(data){
},
error:function(data){
console.error(data);
}
});
后端需要利用CORS在一个域上添加标头允许另一个域的请求访问。
头信息设置如下:
header(“Access-Control-Allow-Origin:允许访问的域名”)
如果需要任何域来访问可以设置为:
header(“Access-Control-Allow-Origin:*”)感谢这位仁兄 记录一下 谢谢 原博客地址:http://www.cnblogs.com/shludan/p/5552062.html
本文介绍了解决AJAX跨域登录时无法实时更新session的问题。通过在前端设置withCredentials选项并配置后端CORS策略,实现了跨域登录功能,并确保了登录状态能被正确检测。
1968

被折叠的 条评论
为什么被折叠?



