禁用cookie后session失效问题(八)

禁用cookie后,session失效,是因为session它是使用cookie来保存jsessionid值,如果禁用了cookie,session使用不了。

解决方案:我们认为将jsessionid的值添加到请求中,就可以。

http://localhost:8080/day9_2/demo2;jsessionid=....

可以通过URL重写:

方法1:response.encodeRedirectURL(java.lang.String url) 用于对sendRedirect方法后的URL地址进行重写

方法2:response.encodeURL(java.lang.String url) 用于对表单action和超链接URL地址进行重写

注意:对于以上操作,如果检测到浏览器禁用了cookie,会在路径上添加jsessionid的值,否则不会添加。

package com.it.servlet.session;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

public class Demo1Servlet extends HttpServlet {

	public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		response.setContentType("text/html;charset=utf-8");
		//获取session
		HttpSession session = request.getSession();
		//session是一个域对象
		session.setAttribute("sname", "手机");
		String path = response.encodeURL("/day9_2/demo2");
		System.out.println(path);
		response.getWriter().write("<a href='"+path+"'>跳转到demo2Servlet</a>");
	}

	
	public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		doGet(request, response);
	}

}
package com.it.servlet.session;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class Demo2Servlet extends HttpServlet {

	
	public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		String value = (String) request.getSession().getAttribute("sname");
		System.out.println(value);
	}

	
	public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		doGet(request, response);
	}

}

注意:以上操作如果检测到浏览器禁用了cookie,会在路径上添加jsessionid值,否则,不会添加。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值