URL 重写

https://blog.csdn.net/qq_42857603/article/details/82897870

URL重写,也属于会话追踪技术的一种.

URL重写解决了这样一个问题:
    当前浏览器把cookie禁用之后,浏览器在发请求的时候,就不会把cookie带到服务器端了(其中最重要的也包括JSESSIONID),因为禁用cookie之后浏览器拒绝一切站点向浏览器写入cookie的(注意再禁用之前是否已经有一些已经存在的cookie了),这样的话,多个请求就不能在服务器端拿到同一个session对象了(因为发送请求的时候没有把JSESSIONID的值传给服务器)。

    把JSESSIONID从客户端传给服务器,有俩种方式:
    1.JSESSIONID保存在cookie文件中,浏览器发送请求的时候把这个cookie文件中的数据带给服务器(cookie).

    2.通过传参的方式,把JSESSIONID的值通过要访问的URL传给服务器.(URL重写)

    
    如何实现URL重写:
    String url = resp.encodeURL("..");
    这个方法参数就是我们要访问的URL,这个方法会把重写后的URL以字符串的形式返回.

    例如:在一个超链接中,本来要访问的URL是:<a href="GetDataFromSession">
    
    重写后:
    <a href="GetDataFromSession;jsessionid=5480EF9016295A73DC56731A2F123246">
   

package com.briup.web.Servelt;
 
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
@WebServlet("/ck")
//http://127.0.0.1:8888/jd1812_web/ck
public class URLCookie extends HttpServlet {
	private static final long serialVersionUID = 1L;
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		// TODO Auto-generated method stub
		HttpSession session=
				request.getSession();
		//当浏览器禁用Cookie时,每次访问都要手动添加jesessionid
//		System.out.println("sess"+session.getId());
//		//String path="sess;jsessionid="+session.getId();
		//encodeURL自动在资源名称后面拼接jsessionid值
		//在encodeURL前面需要获取session对象 
		String path=response.encodeURL("sess");
		System.out.println(path);
		request.setAttribute("id", session.getId());
//		response.sendRedirect(path);
		request.getRequestDispatcher("/test.jsp").forward(request, response);
	}
 
	/**
	 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
	 */
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		// TODO Auto-generated method stub
		doGet(request, response);
	}
 
}
 
 
 
//test.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
    <%
	String path = request.getContextPath();
	String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
	%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<base href="<%=basePath %>">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title></title>
</head>
<body>
<a href="sess;jsessionid=${requestScope.id}">点击</a>
<!-- El表达式可以获取后台4个容器的内容 -->
request:${requestScope.num}<br>
session:${sessionScope.num}<br>
application:${applicationScope.num}
</body>
</html>
 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值