本篇博客让我们来了解JavaWeb中的会话和会话技术,了解什么是Cookie,掌握Cookie对象的使用.
1.什么是会话?
1.会话:一次会话中包含多次请求和响应.
一次会话:浏览器第一次给服务器资源发送请求,会话建立,直到有一方断开为止.
2.会话的功能:在一次会话中,实现数据共享.
3.会话的方式:
1.客户端会话技术:Cookie
2.服务器端会话技术:Session
2.Cookie:
1.概念:客户端会话技术,将数据保存到客户端
2.常用方法:
创建Cookie对象,绑定数据 | new Cookie(String name,String value) |
发送Cookie对象 | resp.addCookie(Cookie cookie) |
获取Cookie,拿到数据 | Cookie[] req.getCookies() |
3.实现原理:
基于响应头set-cookie和请求头cookie实现
4.注意事项:
1.一次可以发送多个cookie.可以创建多个cookie对象,使用response调用多次addCookie方法发送cookie即可.
2.cookie在浏览器中保存的保存时间.使用setMaxAge(int seconds)方法可以将cookie数据写到文件中,并且指定cookie的存活时间.
3.cookie存储数据在客户端浏览器中.
3.Cookie在浏览器和服务器之间的传输过程:
当用户第一次访问服务器时,服务器会在响应消息中增加Set-Cookie头字段,将用户信息以Cookie的形式发送给浏览器.用户浏览器一旦接收到服务器发送的Cookie信息,就会将它保存到自身缓冲区中.这样,当浏览器后继续访问服务器时,都会在请求消息中将用户信息以Cookie的形式发送给服务器,从而使服务器分辨当前请求是那个用户发出的.
4.实现显示用户上次服务时间的显示
【任务目标】
当用户访问某些Web应用时,经常会显示该用户上次的访问时间。
【代码实现】
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
/**
* @author Sun
* @version 2021.2
* @date 2022/5/5 17:28
*/
@WebServlet("/LastAssessTime")
public class LastAssessServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//指定服务器输出内容编码方式,以防发生乱码
resp.setContentType("text/html;charset=utf-8");
//获取所有的cookie
Cookie[] cookies=req.getCookies();
//定义flag 用于判断cookies是否为空
boolean flag=false;
//遍历cookie数组
if (cookies!=null && cookies.length>0){
for (Cookie cookie:cookies) {
//获取cookie的名称
String name=cookie.getName();
//判断名称是否为LastAssessTime
if ("LastAssessTime".equals(name)){
//该cookie不是第一次访问
flag=true;
//响应数据
//获取cookie中的value时间
String value=cookie.getValue();
resp.getWriter().write("上次访问时间"+value);
//设置cookie的value
//获取当前时间的字符串,重新设置cookie的值,重新发送cookie
Date date=new Date();
SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd-hh:mm:ss");
String time= sdf.format(date);
cookie.setValue(time);
//设置cookie存活时间
cookie.setMaxAge(60*60*24*5);//5天
//加入当前cookie请求时间
resp.addCookie(cookie);
break;
}
}
}
if (cookies==null || cookies.length==0 || flag==false){
//设置cookie的value
Date date=new Date();
SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd-hh:mm:ss");
String time= sdf.format(date);
Cookie cookie=new Cookie("LastAssessTime",time);
//设置cookie存活时间
cookie.setMaxAge(60*60*24*5);//5天
//加入当前cookie请求时间
resp.addCookie(cookie);
resp.getWriter().write("欢迎首次访问");
}
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
this.doPost(req,resp);
}
}
运行结果:
第一次访问:
关闭浏览器后重新访问:
所以关闭浏览器,重新打开依旧显示时间。
但在默认情况下,Cookie对象的maxAge属性值为-1,即关闭浏览器时删除当前Cookie对象,这样的话重启浏览器访问则会显示:欢迎首次访问。
如果觉得对你有帮助,就给小孙留下一个点赞+收藏吧
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/119582.html