客户端禁用Cookie后session失效的问题

客户端禁用Cookie后session会失效,该如何解决?

解决方法:使用URL重写技术
	URL重写:在原来的URL后面加上";jsessionid=123456789" 即:url--->url;JSESSIONID=123
	注意:	
		*For robust session tracking, all URLs emitted by a servlet should be run through this method. 
		 Otherwise, URL rewriting cannot be used with browsers which do not support cookies. (文档)
		 即:要在整个交互过程中始终保持会话状态,如果使用URL重写技术,就必须对网站中的所有URL地址都重写,否则URL重新就失败了!!!

		*本机测试时:客户端禁用Cookie对http://localhost访问的无效,对http://127.0.0.1的访问有效
	实现方法:
		1、	HttpServletResponse.encodeURL(String url)	(常用)
			用于对表单action和超链接的url地址进行重写
		2、	HttpServletResponse.encodeRedirectURL(String url) 
			用于对sendRedirect方法后的url地址进行重写。

		* 一般情况选择encodeURL
		* 两个方法区别在于:如果参数为空字符串,返回结果不同。
		* 两个方法都会自动去判断用户是否禁用了Cookie,没有禁用,则不重写;如果禁用了就重写。
		tomcat6.0 的实现:
		org.apache.catalina.connector.Response.java中的方法:

			public String encodeURL(String url) {
				// toAbsolute() 把url转换为绝对地址
				String absolute = toAbsolute(url);
				if (isEncodeable(absolute)) {
					// 两种方法的唯一区别!
					if (url.equalsIgnoreCase("")){
						url = absolute;
					}
					return (toEncoded(url, request.getSessionInternal().getIdInternal()));
				} else {
					return (url);
				}
			}
			
			 public String encodeRedirectURL(String url) {

				if (isEncodeable(toAbsolute(url))) {
					return (toEncoded(url, request.getSessionInternal().getIdInternal()));
				} else {
					return (url);
				}
			}


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值