import java.io.PrintWriter;
public class SetcookieServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//1.创建cookie对象
//首先需要一个cookie对象,这里我们需要两个cookie对象,一个来存储用户名(username——java),一个来存储密码(pwd——javas)
cookie username = new cookie(“uesrname”,“java”);
cookie pwd = new cookie(“pwd”,“javas”);
//当我们创建好两个cookie对象之后,就可以对这两个对象进行一系列操作
//比如:设置他的过期时间,这里我们将username的过期时间设置为永久
username.setMaxAge(-1);
//密码pwd的过期时间设置为一分钟,注意他的过期时间是以秒为单位
pwd.setMaxAge(60);
//2.将 cookie 对象关联到response上
resp.addcookie(username);
resp.addcookie(pwd);
//显示给用户部分的信息
resp.setCharacterEncoding(“utf-8”);
resp.setContentType(“text/html”);
//然后写入响应给客户端的内容
PrintWriter writer = resp.getWriter();
writer.println(“
cookie 设置成功”);}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
this.doGet(req, resp);
}
}
注意:一定不要忘记配置web.xml文件
结果验证:
获取cookie信息代码
import javax.servlet.ServletException;
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.io.PrintWriter;
public class GetcookieServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//读取cookie的信息
//因为客户端的cookie可能会有多个,所以我们使用数组来接收,注意:cookie是从request获取的
cookie[] cookies = req.getcookies();
resp.setContentType(“text/html”);
resp.setCharacterEncoding(“utf-8”);
PrintWriter writer = resp.getWriter();
//然后读取cookie的内容
for (cookie item: cookies
) {
writer.println(String.format(“
cookie key: %s,cookie value: %s”,item.getName(),item.getValue()));}
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
this.doGet(req, resp);
}
}
注意:
1.不要忘记配置web.xml文件
2.因为上面我们设置cookie信息的时候,pwd的过期时间为一分钟,当我们要去获取cookie信息的时候就看时间不够,所以建议修改更长的过期时间。
验证结果
Servlet SessionSession定义:session是存储在服务器上的文本文件,并保留用户的各种跟踪信息
Session作用:会话保持,如完成用户的登录与状态保持,因为在服务器端,所以相对安全一些。
Session在Servlet里的存储形式
Servlet操作session方法session是借助cookie实现的
HttpSession对象
-
Servlet提供了HttpSession接口,该接口提供了一种跨多个页面请求或访问网站时识别用户以及存储有关用户信息的方式
-
Servlet容器使用这个接口来创建一个HTTP客户端和HTTP服务器之间的session会话,会话持续一个指定的时间段。跨多个连接或页面请求
-
可以通过调用HttpServletReq
《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》
【docs.qq.com/doc/DSmxTbFJ1cmN1R2dB】 完整内容开源分享
uest的公共方法 getSession() 来获取 HttpSession对象(如:HttpSession session = request.getSession()),需要在向客户端发送任何文档内容之前调用 request.getSession()
HttpSession 对象中可用的几个重要的方法:
小知识点:session都是通过request进行操作,而cookie是通过request和response进行操作。
代码示例
关于session的读写操作代码
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.Date;
public class SessionServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//关于 session 的读写
//1.先获取到session到对象
HttpSession session = req.getSession();
//2.得到session的属性
//2.1获取到session的ID
String sessionID = session.getId();
//返回响应信息
resp.setContentType(“text/html”);
resp.setCharacterEncoding(“utf-8”);
PrintWriter writer = resp.getWriter();
writer.println(“
欢迎访问页面”);//输出sessionID
writer.println(String.format("
SessionID : %s ",sessionID));//输出session的创建时间,因为session的创建时间是一个时间戳,所以我们需要将其强转成我们能看得懂的时间
writer.println(String.format(“
Session创建时间: %s”,new Date(session.getCreationTime())));//输出session的最后访问时间
writer.println(String.format(“
Session的最后访问时间: %S”,new Date(session.getLastAccessedTime())));}



