浏览器与服务器之间的每一个回话都有一个session,session id 是位置标志,在java环境中,这个session的 id 就叫做jsessionid。
可以直接中session中获取,比如String jsessionid = request.getSession.getId();
开启一段新的回话时,服务器会把jsessionid传到浏览器,浏览器存在cookie中,
存在cookie以后,chrome浏览器的Application中可以查看:
第一次建立连接的时候,
服务器会通过Response Headers 回传jsessionid。即浏览器第一次请求服务器时cookie中并没有jsessionid,
但是我们可以想到从Response Headers 对象中获取jsessionid,但是js获取Response Headers 对象后打印出来,此对象里面并不存在Set-Cookie这个属性,原因不详。所以不能从Set-Cookie中得到jsessionid。那么只能手动把服务器中session的id传到前台。
假设已经jsessionid已经被设置进cookie中了,我们可以直接从cookie中获取。实现代码如下:
function getSessionId(){
var c_name = 'JSESSIONID';
if(document.cookie.length>0){
c_start=document.cookie.indexOf(c_name + "=");
if(c_start!=-1){
c_start=c_start + c_name.length+1;
c_end=document.cookie.indexOf(";",c_start);
if(c_end==-1) c_end=document.cookie.length;
return unescape(document.cookie.substring(c_start,c_end));
}
}
}
但是第一次请求时这样并不能获取JSESSIONID。
改进一下代码:
java代码:
String sessionId = session.getId();
model.addAttribute("JSESSIONID", sessionId);
return "index";
html代码(index.jsp):
<input type="hidden" id="JSESSIONID" value="${JSESSIONID}"/>
javascript代码:
function getSessionId(){
var c_name = 'JSESSIONID';
if(document.cookie.length>0){
c_start=document.cookie.indexOf(c_name + "=");
if(c_start!=-1){
c_start=c_start + c_name.length+1;
c_end=document.cookie.indexOf(";",c_start);
if(c_end==-1) c_end=document.cookie.length;
return unescape(document.cookie.substring(c_start,c_end));
}else{
//手动从后台传来sessionid
var JSESSIONID = $('#JSESSIONID').val();
return JSESSIONID;
}
}
}
这样的话不管是第一次建立连接还是第n次请求,都可以获取jsessionid了。