最近的项目中涉及到了应用ajax请求后台系统登录,身份认证失败,经过不断的调试终于找到解决方案。

应用场景:

  项目测试环境:前端应用HTML,js,jQuery ajax请求,部署在Apache服务器;后端业务系统应用spring mvc,mybatis,部署在tomcat服务器。当在一个系统需要调用另一个系统的时候,就会出现跨域的问题,即本次我们遇到了ajax请求的跨域问题。

  系统权限安全框架使用shiro,系统登录时发送ajax请求调用springmvc action方法进行系统登录及身份认证,角色权限授权等。由于ajax请求时,浏览器会认为携带Cookie是不安全请求,将限制其携带Cookie信息,导致登录action方法无法获取并响应相应的Cookie(JSESSIONID),身份认证及角色权限授权、退出等都操作都无法正常使用。

解决方案:

  1、当发送ajax请求时,查看浏览器调试信息中Headers和Cookies,发现发送到后端的跨域请求并没有携带 cookie 信息,可见Request Headers不包含Cookie属性,Response Headers中也不包含Set-Cookie属性,导致无法得到后台业务系统的认证。

  

  解决:在ajax里添加withCredentials的配置,允许其请求携带cookie信息。通过设置withCredentials=true,发送Ajax时,Request header中便会带上 Cookie 信息。

$.ajax({
type: "post",
url:url,
async:false,
data:datatosend,
dataType:"json",
beforeSend: function(xhr) {
xhr.withCredentials = true;
}
crossDomain:true,
success: function (data) {
var a=JSON.stringify(data);
if(data.result==true){
  ...........
   }else{
       ...........
     }
},
error:function (data) {
var a=JSON.stringify(data);
alert(a);
}
});

  注意:<踩过的坑>我们在beforeSend方法里设置withCredentials=true;在上述代码情境下,如果使用xhrFields:{ withCredentials:true }方法,则允许携带cookie信息的配置并不生效。(原因:ajax中添加了async:false,即修改为同步了,在窗口上下文的同步模式中,已不再支持使用XMLHttpRequest的withCredentials属性)。当保持异步模式时,我们可以更换对应的方法。注意2种方法的区分。

  2、服务器server端要配置Access-Control-Allow-Credentials

  我们在客户端设置了withCredentials=true 参数,对应着,服务器端要通过在响应 header 中设置Access-Control-Allow-Credentials = true来运行客户端携带证书式的访问。通过对Credentials参数的设置,就可以保持跨域Ajax时传递的Cookie。

response.setHeader("Access-Control-Allow-Credentials", "true");

  3、服务器server端要配置Access-Control-Allow-Origin

  到以上配置为止,发送ajax请求,我们发现还会出现一个错误,提示我们 Access-Control-Allow-Origin 不能用 * 通配符。原因是:当服务器端 Access-Control-Allow-Credentials = true时,参数Access-Control-Allow-Origin 的值不能为 '*' 。

  我们重新设置Access-Control-Allow-Origin的值,当服务器端接收到请求后,在返回响应时,把请求的域Origin填写到响应的Header信息里(即谁访问我,我允许谁),代码如下:

response.setHeader("Access-Control-Allow-Origin", request.getHeader("Origin"));

  ok,到目前问题搞定了,经过测试,可成功传递及响应cookie信息,浏览器调试信息如下图所示:

  

  

  

最新文章

  1. ovirt配置为cas登录
  2. 【NEUQACM OJ】1018: A+B again
  3. cs端调用Ajax
  4. Android基于mAppWidget实现手绘地图(七)–根据坐标添加地图对象
  5. Windows7 IE10运行不了JavaScript的问题
  6. c语言小程序
  7. (一)S5PV210开发板常用易忘操作记录
  8. 『重构--改善既有代码的设计』读书笔记----Extract Method
  9. 使用idea将本地项目上传至github及clone
  10. ac automaton 专题
  11. C++中实现回调机制的几种方式(一共三种方法,另加三种)
  12. PVPlayer的实现方式
  13. 《深入理解java虚拟机》笔记——简析java类文件结构
  14. Mysql 查询重复的记录
  15. bower 基础认识
  16. Android N 的开机启动流程概述
  17. Java NIO6:选择器1——理论篇
  18. Flutter - 本地化启动列表中App名字
  19. mybatis源码解析7---MappedStatement初始化过程
  20. Percona Xtradb Cluster的设计与实现

热门文章

  1. Ubuntu 16.04下ssh启用root登录
  2. JAVA实现网页快照,存为图片格式
  3. openfire源码解读之将cache和session对象移入redis以提升性能
  4. 使用Jenkins搭建iOS开发的CI服务器
  5. Assembly.Load动态加载程序集而不占用文件 z
  6. Camera setParameters(), getParameters(),unlock()三个方法之间的限制关系
  7. [置顶] kubernetes资源类型--pod和job
  8. ISP基础一
  9. Hadoop之Mapreduce详解
  10. js - 正斜杆网址转换