首页 > 编程知识 正文

跳转带jsessionid问题,jsessionid能换个名字

时间:2023-05-05 07:07:24 阅读:45884 作者:4493

由于服务器端熟悉单行代码,如session.setAttribute (',userInfo ),所以我不太想在服务器和浏览器之间保持会话状态。 好了,我先引用几篇文章的精彩部分。 http://www.xxx.com/xxx_app; jsessionid=xxxxx

你的tomcat,打开FireFox(爱得不得了,一定要安装FireBug),输入localhost就行,打开firebug,点网络,你会看到,浏览器与服务器会话的信息,给出浏览器

(1)第一次请求服务器:

浏览器的请求头信息

HostlocalhostUser-AgentMozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.9.2.6) Gecko/20100625 Firefox/3.6.6Accepttext/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8Accept-Languagezh-cn,zh;q=0.5Accept-Encodinggzip,deflateAccept-CharsetGB2312,utf-8;q=0.7,*;q=0.7Keep-Alive115Connection

keep-alive

 

服务器响应头信息

ServerApache-Coyote/1.1Set-Cookie JSESSIONID=64D21B4D69DFB3041B6375C1932BD6CB; Path=/ Content-Typetext/html;charset=UTF-8Content-Languagezh-CNContent-Length242DateMon, 28 Jun 2010 02:35:29 GMT

(2)第二次请求服务器:

浏览器的请求头信息

HostlocalhostUser-AgentMozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.9.2.6) Gecko/20100625 Firefox/3.6.6Accepttext/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8Accept-Languagezh-cn,zh;q=0.5Accept-Encodinggzip,deflateAccept-CharsetGB2312,utf-8;q=0.7,*;q=0.7Keep-Alive115Connectionkeep-aliveCookie JSESSIONID=64D21B4D69DFB3041B6375C1932BD6CB

服务器响应头信息

ServerApache-Coyote/1.1Content-Typetext/html;charset=UTF-8Content-Languagezh-CNContent-Length242DateMon, 28 Jun 2010 02:37:51 GMT

重复第三次,每四次...第N次请求服务器,浏览器和服务器的请求头信息都是与第二次请求服务器是一样的。


(3)但是,如果你在服务器端加入如下一行代码:

Log.info("SessionId:" + request.getSession().getId());

你会看到,健壮的花生第一次请求服务器时,就会默认有一个新的session被创建,而且在session的有效时间范围内,这个输出值是不会变的,否则,服务器会重新创建一个session,自然,sessionId也就不同了,这段代码的输出自然也会不同了。

 

(4)你必须注意这一点:你用的是浏览器与服务器通信:

有一些事情是浏览器帮助我们去做了,那就是:健壮的花生第一次与服务器通信时,浏览器会保存服务器返回的 Set-Cookie 这个健的值( JSESSIONID=64D21B4D69DFB3041B6375C1932BD6CB ),只要你不关闭浏览器(彻底关闭,关闭选项卡不算),浏览器会从第二次向服务器发出请求开始,一直带上这个键值对,发给服务器。服务器就会知道,这是同一个人(同一个会话)发起的请求。

 

(5)我们再注意一下:request.setAttribute("sysuser",userInfo)这句话:

健壮的花生第一次请求服务器时,这句代码会根据服务器默认产生的session得到ID,并与sysuser=userInfo这个键值对挂上钩(当然,userInfo可以是任何对象),保证唯一关联,检测用户是否登录就是这样实现的。

我一定要声明一点:保持一个会话与用户是否登录是没有任何关系的。

 

(6)再次引深一下,如果你用的不是浏览器,比如说做J2ME开发,怎样保持会话呢?

(1) 在你写完这行代码后:HttpConnection hc = (HttpConnection)Connector.open(httpURL),加入以下代码:( Constant.sessionID只是一个静态变量 )

view plain copy to clipboard print ? 年轻的美女 //在与服务器通信前设置sessionId,维持唯一的一个会话   if (Constant.sessionID != null) {     hc.setRequestProperty("Cookie", AppContext.CurrentAppContext.sessionID);  }   //在与服务器通信前设置sessionId,维持唯一的一个会话if (Constant.sessionID != null) { hc.setRequestProperty("Cookie", AppContext.CurrentAppContext.sessionID);}

 

(2) A:只向服务器读数据,不向服务写数据,B:先向服务器写数据,再从服务器读数据

对于这两种情况,只要你第一次打开openDataInputStream(),这可以加入以下代码( Constant.isLogin 只是一个静态变量boolean ):

 

view plain copy to clipboard print ? 年轻的美女 //每次与服务器通信后,保存 sessionId   String cookie = hc.getHeaderField("Set-Cookie");  if (cookie != null) {        String jsessionId = cookie.substring(0,cookie.indexOf(";"));        if(Constant.sessionID != null && !Constant.sessionID.equals(jsessionId) && Constant.isLogin ){            Log.info("sessionid超时, will get new sessionid, but you must login again");            //设置为未登录状态             Constant.isLogin = false;        }        Constant.sessionID = jsessionId;  }    //每次与服务器通信后,保存 sessionIdString cookie = hc.getHeaderField("Set-Cookie");if (cookie != null) { String jsessionId = cookie.substring(0,cookie.indexOf(";")); if(Constant.sessionID != null && !Constant.sessionID.equals(jsessionId) && Constant.isLogin ){ Log.info("sessionid超时, will get new sessionid, but you must login again"); //设置为未登录状态 Constant.isLogin = false; } Constant.sessionID = jsessionId;} 

这样就可以保持一个会话了。


(7)最后,关于URL重定向

引用一段话:sun帮我们想到了,所以提供了2个方法来使事情变得简单:response.encodeURL()和response.encodeRedirectURL()。这2个方法会判断cookie是否可用,如果禁用了会解析出url中的jsessionid,并连接到指定的url后面,如果没有找到jessionid会自动帮我们生成一个。至于为什么要有2个方法?这2个方法有什么不同?google了一下,说是这2个方法在判断是否要包含jsessionid的逻辑上会稍有不同。在调用 HttpServletResponse.sendRedirect前,应该先调用encodeRedirectURL()方法,否则可能会丢失 Sesssion信息。这2个方法的使用方法如:response.sendRedirect(response.encodeURL("/myapp /input.jsp"));。如果cookie没有禁用,我们在浏览器地址栏中看到的地址是这样的:/myapp/input.jsp,如果禁用了 cookie,我们会看到:/myapp /input.jsp;jsessionid=73E6B2470C91A433A6698C7681FD44F4。所以,我们在写web应用的时候,为了保险起见,应该在程序里的每一个跳转url上都使用这2个方法,来保证session的可用性。



版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。