Servlet规范
十、多个Servlet之间数据共享实现方案:
1、数据共享:OneServlet工作完毕后,将产生数据交给TwoServlet来使用。
2、Servlet规范中提供四种数据共享方案:
-
ServletContext接口(全局作用域对象)
-
Cookie类
-
HttpSession接口(会话作用域对象)
-
HttpServletRequest接口(请求作用域对象)
十一、ServletContext接口:
1、简介:
- 来自于Servlet规范中一个接口。在Tomcat中存在servlet-api.jar在Tomcat中负责提供这个接口实现类。
- 如果两个Servlet来自于同一个网站。彼此之间通过网站的ServletContext
实例对象实现数据共享。 - 开发人员习惯于将ServletContext对象称为【全局作用域对象】
2、工作原理:
每一个网站都存在一个全局作用域对象。这个全局作用域对象【相当于】一个Map,在这个网站中OneServlet可以将一个数据存入到全局作用域对象,当前网站中其他Servlet此时都可以从全局作用域对象得到这个数据进行使用。
3.全局作用域对象生命周期:
- 在Http服务器启动过程中,自动为当前网站在内存中创建一个全局作用域对象。
- 在Http服务器运行期间时,一个网站只有一个全局作用域对象(资源宝贵,不到迫不得已,不会使用)
- 在Http服务器运行期间,全局作用域对象一直处于存活状态
- 在Http服务器准备关闭时,负责将当前网站中全局作用域对象进行销毁处理
总结:全局作用域对象生命周期贯穿网站整个运行期间
4.代码实现: 【同一个网站】OneServlet将数据共享给TwoServlet
public class OneServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//1.通过请求对象向Tomcat索要当前网站全局作用域对象
ServletContext application = request.getServletContext();
//2.将数据添加到全局作用域对象,作为共享数据
application.setAttribute("key", 100);
}
}
public class TwoServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//1.通过请求对象向Tomcat索要当前网站全局作用域对象
ServletContext application = request.getServletContext();
//2.从全局作用域对象得到指定关键字对应的值
Integer number=(Integer)application.getAttribute("key");
}
}
十二、Cookie
1、介绍:
-
Cookie来自于Servlet规范中一个工具类,存在于Tomcat提供servlet-api.jar中
-
如果两个Servlet来自于同一个网站,并且为同一个浏览器/用户提供服务,此时借助于Cookie对象进行数据共享
-
Cookie存放当前用户的私人数据,在共享数据过程中提高服务质量
-
在现实生活场景中,Cookie相当于用户在服务端得到会员卡
2、原理:
用户通过浏览器第一次向【myWeb】网站发送请求,OneServlet在运行期间创建一个Cookie存储与当前用户相关数据,OneServlet工作完毕后,【将Cookie写入到响应头】交还给当前浏览器。
浏览器收到响应响应包之后,将cookie存储在浏览器的缓存一段时间之后,用户通过【同一个浏览器】再次向【myWeb网站】发送请求TwoServlet时。【浏览器需要无条件的将myWeb网站之前推送过来的Cookie,写入到请求头】发送过去此时TwoServlet在运行时,就可以通过读取请求头中cookie中信息,得到OneServlet提供的共享数据
3、代码实现: 同一个网站 OneServlet 与 TwoServlet 借助于Cookie实现数据共享
public class OneServlet extends HttpServlet {
public void doGet(HttpServletRequest request,HttpServletResponse response){
//1.创建一个cookie对象,保存共享数据(当前用户数据)
Cookie card1 = new Cookie("key1","123");
Cookie card2= new Cookie("key2","456");
//一个cookie中只能存放一个键值对
//这个键值对的key与value只能是String
//键值对中key不能是中文
//2.将cookie写入到响应头,交给浏览器
response.addCookie(card1);
response.addCookie(card2)
}
}
此时,浏览器接收到的数据为;状态码:200 cookie: key1=123;key2=456
浏览器再次向【myWeb】网站发送请求访问TwoServlet---->请求包 【url:/myWeb/two method:get】Cookie:key1=123;key2=456;
public class TwoServlet extends HttpServlet {
public void doGet(HttpServletRequest request,HttpServletResponse resp){
//1.调用请求对象从请求头得到浏览器返回的Cookie
Cookie cookieArray[] = request.getCookies();
//2.循环遍历数据得到每一个cookie的key 与 value
for(Cookie card:cookieArray){
String key = card.getName(); //读取key "key1"
Strign value = card.getValue();//读取value "123"
//继续提供服务
}
}
}
4、Cookie生命周期:
-
在默认情况下,Cookie对象存放在浏览器的缓存中。因此只要浏览器关闭,Cookie对象就被销毁掉
-
在手动设置情况下,可以要求浏览器将接收的Cookie存放在客户端计算机上硬盘上,同时需要指定Cookie在硬盘上存活时间。在存活时间范围内,关闭浏览器关闭客户端计算机,关闭服务器,都不会导致Cookie被销毁。在存活时间到达时,Cookie自动从硬盘上被删除。
cookie.setMaxAge(60); //cookie在硬盘上存活1分钟
十三、HttpSession接口:
1、介绍:
-
HttpSession接口来自于Servlet规范下一个接口。存在于Tomcat中servlet-api.jar,其实现类由Http服务器提供。Tomcat提供实现类存在于servlet-api.jar
-
如果两个Servlet来自于同一个网站,并且为同一个浏览器/用户提供服务,此时借助于HttpSession对象进行数据共享
-
开发人员习惯于将HttpSession接口修饰对象称为【会话作用域对象】
2、HttpSession 与 Cookie 区别:
-
存储位置:
Cookie:存放在客户端计算机(浏览器缓存/硬盘)
HttpSession:存放在服务端计算机内存 -
数据类型:
Cookie对象存储共享数据类型只能是String
HttpSession对象可以存储任意类型的共享数据Object -
数据数量:
一个Cookie对象只能存储一个共享数据,HttpSession使用map集合存储共享数据,所以HttpSession可以存储任意数量共享数据。 -
参照物:
Cookie相当于客户在服务端【会员卡】
HttpSession相当于客户在服务端【私人保险柜】
3、代码实现: 同一个网站【myWeb】下OneServlet使用HttpSession将数据传递给TwoServlet的过程
public class OneServlet extends HttpServlet{
public void doGet(HttpServletRequest request,HttpServletResponse response){
//1.调用请求对象向Tomcat索要当前用户在服务端的私人储物柜
HttpSession session = request.getSession();
//2.将数据添加到用户私人储物柜
session.setAttribute("key",共享数据)
}
}
TwoServlet接收:
public class TwoServlet extends HttpServlet{
public void doGet(HttpServletRequest request,HttpServletResponse response){
//1.调用请求对象向Tomcat索要当前用户在服务端的私人储物柜
HttpSession session = request.getSession();
//2.从会话作用域对象得到OneServlet提供的共享数据
Object 共享数据 = session.getAttribute("key");
}
}
4、Http服务器如何将用户与HttpSession连接的原理:
简单来说,就是通过【Cookie】建立两者的连接
- Tomcat在创建一个HttpSession对象时自动为这个HttpSession对象生成一个编号,再将编号保存到Cookie对象,推送到当前浏览器缓存中,且只能保存到缓存,而不能保存到硬盘中。
- Cookie的键名称唯一且固定为JSESSIONID。
Cookie:JSESSIONID=编号
- 当用户再次来访时,Tomcat根据请求头中的JSESSIONID确认用户是否有HttpSession对象,以及判断是哪一个HttpSession对象。
5、getSession() 与 getSession(false)
- getSession(): 如果当前用户在服务端已经拥有了自己的Session对象【私人储物柜】,要求tomcat将这个Session对象进行返回,如果当前用户在服务端尚未拥有自己的Session对象,要求tocmat为当前用户创建一个全新的Session对象
- getSession(false):如果当前用户在服务端已经拥有了自己的Session对象,要求tomcat将这个Session对象进行返回,如果当前用户在服务端尚未拥有自己的Session对象,此时Tomcat将返回null。
6.HttpSession销毁时机:
- 用户与HttpSession关联时使用的Cookie只能存放在浏览器缓存中.
- 在浏览器关闭时,意味着用户与他的HttpSession关系被切断
- 由于Tomcat无法检测浏览器何时关闭,因此在浏览器关闭时并不会导致Tomcat将浏览器关联的HttpSession进行销毁
- 为了解决这个问题,Tomcat为每一个HttpSession对象设置【空闲时间】这个空闲时间默认30分钟,如果当前HttpSession对象空闲时间达到30分,此时Tomcat认为用户已经放弃了自己的HttpSession,此时Tomcat就会销毁掉这个HttpSession。
7.HttpSession空闲时间手动设置:web.xml
<session-config>
<session-timeout>5</session-timeout> <!--当前网站中每一个session最大空闲时间5分钟-->
<!--为了安全起见,最大空闲时间一般都往小的设置-->
</session-config>
十四、HttpServletRequest接口实现数据共享
1、介绍:
- 在同一个网站中,如果两个Servlet之间通过【请求转发】方式进行调用,彼此之间共享同一个请求协议包。而一个请求协议包只对应一个请求对象因此servlet之间共享同一个请求对象,此时可以利用这个请求对象在两个Servlet之间实现数据共享。
- 在请求对象实现Servlet之间数据共享功能时,开发人员将请求对象称为【请求作用域对象】
2、命令实现: OneServlet通过请求转发申请调用TwoServlet时,需要给TwoServlet提供共享数据
public calss OneServlet extends HttpServlet{
public void doGet(HttpServletRequest request,HttpServletResponse response){
//1.将数据添加到【请求作用域对象】中attribute属性
request.setAttribute("key","hello World"); //数据类型可以任意类型Object
//2.向Tomcat申请调用TwoServlet
request.getRequestDispatcher("/two").forward(request,response)
}
}
public calss TwoServlet extends HttpServlet{
public void doGet(HttpServletRequest request,HttpServletResponse response){
//从当前请求对象得到OneServlet写入到共享数据
Object data = request.getAttribute("key");
}
}