《Servlet和JSP学习指南》一第2章 Session管理 2.1 网址重写

简介: 本节书摘来自华章出版社《Servlet和JSP学习指南》一书中的第2章,第2.1节,作者(加)Budi Kurniawan,更多章节内容可以访问云栖社区“华章计算机”公众号查看

第2章 Session管理

Session管理(或Session追踪)是Web应用程序开发中一个非常重要的主题。这是因为Web语言HTTP是无状态的。在默认情况下,Web服务器不知道一个HTTP请求是来自初次用户,还是来自之前已经访问过的用户。
例如,webmail应用程序要求其用户在查看邮件之前要先登录。但是,一旦用户输入正确的用户名和密码,用户在访问应用程序的其他部分时,就不应该再次提示他们登录。应用程序需要记住哪些用户已经登录成功。换句话说,它必须能够管理用户Session。
本章讲解可以用于保持状态的4种方法:网址重写(URL rewriting)、隐藏域、cookie及HttpSession对象。本章展示的范例都是app02a应用程序中的内容。

2.1 网址重写

网址重写是一种Session追踪技术,需要将一个或多个token作为一个查询字符串添加到一个URL中。token的格式一般是键=值:
image

注意,URL和token之间要用一个问号(?)隔开,两个token之间则是用一个&符号隔开。
如果token不必在过多的URL中四处携带,那么网址重写就比较合适。采用网址重写的缺点如下:
在有些Web浏览器中,URL限制为2000个字符。
仅当有链接要插入值时,值才能转换成后面的资源。此外,要把值添加到静态页面的链接中,可不是一件容易的事情。
网址重写必须在服务器端有效。所有的链接都必须带有值,这样可能出现一个问题,即一个页面中可能会有许多个链接。
某些字符,例如空格、&符号及问号都必须进行编码。
添加到URL中的信息是明显可见的,这种情况有时可不是我们所期待的。
由于上述局限性,网址重写只适用于那些既需要保持,却又不跨越太多页面,并且又不太重要的信息。
举个例子,代码清单2-1中的Top10Servlet类是一个Servlet,它展示了伦敦和巴黎这两座城市中十大最受人喜爱的旅游胜地。信息分两页显示。第一页显示所选城市中前五大最受人喜爱的旅游胜地,第二个显示接下来的五个。Servlet利用网址重写追踪被选城市和页码。它继承HttpServlet,并利用/top10 URL模式调用。
image
image
image
image
image

当第一个用户请求Servlet时,调用init方法,并填充两个类级List:londonAttractions和parisAttractions,它们每一个都包含十个旅游胜地。
每一次请求都会调用doGet方法,查看URL是否包含请求参数city,以及它的值是否为“london”或者“paris”。方法会根据这个参数的值调用showAttractions或者showMainPage。
image

最初,用户会不带请求参数调用Servlet,并且还会调用showMainPage。这是一个简单的方法,它给浏览器发送了两个超链接,每个链接中都嵌有一个token:city=cityName。用户会看到如图2-1所示的屏幕。现在,用户可以选择其中一个城市了。
如果你打开页面源代码,就会看到主体标签中有以下HTML标签:
image

image

最值得关注的是a标签的href属性值,它包含一个问号,接着是token:city=london或者city=paris。任何相对的URL(没有协议部分的URL)都会被当作是相对于当前页面的URL。换句话说,如果单击了页面中的某一个超链接,那么:

image

就会被发送到服务器。
一旦用户单击其中一个超链接,doGet方法就会找到请求参数city,并将控制权传给showAttractions方法,然后查看URL,看它里面是否包含请求参数page。如果没有请求参数page,或者它的值不能转换成数字,就会假设这个值为1,该方法就会发送被选中城市的前五个旅游胜地。图2-2展示了选中伦敦时的情况。
除了城市中的旅游胜地之外,showAttractions还会发送三个超链接:Select City、Page 1及Page 2。Select City会调用没有请求参数的Servlet。Page 1和Page 2包含两个token:city和page。
image

如果选择了伦敦,并单击Page 2,它就会将这个URL发送到服务器,并在后面添加两个键/值token:
image

这时就会看到伦敦前十大旅游胜地的后五个,如图2-3所示。

image

这个范例展示了如何利用网址重写来嵌入一个城市,以便服务器知道要在第二页中显示什么内容。

相关文章
|
11月前
|
Java 容器
【学习笔记】Jsp与Servlet技术
【学习笔记】Jsp与Servlet技术
224 0
|
11月前
|
缓存 Java Spring
servlet和SpringBoot两种方式分别获取Cookie和Session方式比较(带源码) —— 图文并茂 两种方式获取Header
文章比较了在Servlet和Spring Boot中获取Cookie、Session和Header的方法,并提供了相应的代码实例,展示了两种方式在实际应用中的异同。
973 3
servlet和SpringBoot两种方式分别获取Cookie和Session方式比较(带源码) —— 图文并茂 两种方式获取Header
|
SQL Java 数据库
jsp中使用Servlet查询SQLSERVER数据库中的表的信息,并且打印在屏幕上
该博客文章介绍了在JSP应用中使用Servlet查询SQL Server数据库的表信息,并通过JavaBean封装图书信息,将查询结果展示在Web页面上的方法。
jsp中使用Servlet查询SQLSERVER数据库中的表的信息,并且打印在屏幕上
|
缓存 安全 Java
Java服务器端技术:Servlet与JSP的集成与扩展
Java服务器端技术:Servlet与JSP的集成与扩展
123 3
|
存储 缓存 前端开发
Servlet与JSP在Java Web应用中的性能调优策略
Servlet与JSP在Java Web应用中的性能调优策略
130 1
|
12月前
|
存储 安全 搜索推荐
探索研究Servlet Session 跟踪
【9月更文挑战第27天】
113 0
|
供应链 前端开发 Java
JSP+servlet+mybatis+layui服装库存管理系统(大三上学期课程设计)
这篇文章通过一个服装库存管理系统的实例,展示了在Spring Boot项目中使用Ajax、JSON、layui、MVC架构和iframe等技术,涵盖了注册登录、权限管理、用户管理、库存管理等功能,并提供了系统运行环境和技术要求的详细说明。
JSP+servlet+mybatis+layui服装库存管理系统(大三上学期课程设计)
|
存储 Java 关系型数据库
基于Servlet和JSP的Java Web应用开发指南
基于Servlet和JSP的Java Web应用开发指南
334 0
|
前端开发 安全 Java
在Java服务器端开发的浩瀚宇宙中,Servlet与JSP犹如两颗璀璨的明星,它们联袂登场,共同编织出动态网站的绚丽篇章。
在Java服务器端开发的浩瀚宇宙中,Servlet与JSP犹如两颗璀璨的明星,它们联袂登场,共同编织出动态网站的绚丽篇章。
98 0
|
存储 Java 关系型数据库
基于Servlet和JSP的Java Web应用开发指南
【6月更文挑战第23天】构建Java Web应用,Servlet与JSP携手打造在线图书管理系统,涵盖需求分析、设计、编码到测试。通过实例展示了Servlet如何处理用户登录(如`LoginServlet`),JSP负责页面展示(如`login.jsp`和`bookList.jsp`)。应用基于MySQL数据库,包含用户和图书表。登录失败显示错误信息,成功后展示图书列表。部署到Tomcat服务器测试功能。此基础教程为深入Java Web开发奠定了基础。
253 10