目录
HTTP不能保存各种状态,简而言之他是一次性的。
像我们做网站,登录的时候,点击保存密码,自动登录等,是要一直或者一段时间内存在的,但也不能一直存在,他也需要有一个失效期,要不然计算机储存的数据会越来越多。这个时候就需要cookie
Cookie是一些数据,储存于你电脑上的文本文件中。保存HTTP状态,以键值对的形式存储在浏览器中。当下一次用户访问该网页的时候,可以在cookie里获取到之前储存的值(访问记录)
Cookie cookie = new Cookie("name","admin");
cookie.setMaxAge(1000);
resp.addCookie(cookie);
那怎么使用cookie呢:
cookie是用于客户端浏览器的,那肯定是需要用servlet
我们根据真实情况来写一个使用cookie的实例:
首先肯定是在servlet里:doGet/doPost方法
获取网页传来的cookie:
Cookie[] cookies = req.getCookies();
判断这个cookie到底有没有值,有值得话就代表访问过,没有就代表没有
- if(Objects.nonNull(cookies) && cookies.length>0){
- //有
- }else{
- //没有cookie
- }
代码:如果有获取key和value,如果没有就发一个
- //1.获取cookie
- Cookie[] cookies = req.getCookies();
- if(Objects.nonNull(cookies) && cookies.length>0){
- //有cookie的情况(之前登陆过)
- System.out.println("发现了");
- for (Cookie cookie : cookies) {
- System.out.println(cookie.getName()+"->"+cookie.getValue())
- }
- }else{
- //没有登陆过
- System.out.println("没有发现cookie");
- //创建cookie
- Cookie cookie = new Cookie("name", "admin");
- //设置最大时效
- cookie.setMaxAge(8000);
- //把cookie放到响应头中
- resp.addCookie(cookie);
- }
继承HttpServlet
- @WebServlet("/cookie.do")
- public class cookie extends HttpServlet {
- @Override
- protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
- String username = req.getParameter("username");
- String password = req.getParameter("password");
- if(Objects.equals(username,"admin") && Objects.equals(password,"123456")){
- Cookie cookie = new Cookie("username", username);
- cookie.setMaxAge(1000*24*60);
- resp.addCookie(cookie);
- }else{
- username=null;
- Cookie[] cookies = req.getCookies();
- if(Objects.nonNull(cookies) && cookies.length>0){
- for (Cookie cookie : cookies) {
- String name =cookie.getName();
- if("username".equals(name)){
- String va=cookie.getValue();
- username=va;
- }
- }
- }
- }
- if(Objects.nonNull(username)){
- resp.sendRedirect("success.html");
- }else{
- resp.sendRedirect("cookie.html");
- }
- }
- @Override
- protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
- doGet(req, resp);
- }
- }
html:
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- </head>
- <body>
- <form action="cookie.do" method="post">
- 账户:<input type="text" name="username">
- 密码:<input type="text" name="password">
- <input type="submit" value="走你">
- </form>
- </body>
- </html>
在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下)。因此,在需要保存用户数据时,服务器程序可以把用户数据写到用户浏览器独占的session中,当用户使用浏览器访问其它程序时,其它程序可以从用户的session中取出该用户的数据,为用户服务。
获取session会话
HttpSession session = req.getSession();
把username放入session中
session.setAttribute("username",username);
让session销毁
session.invalidate();
设置session过期时间
session.setMaxInactiveInterval(3000);
根据key的值删除对应的属性
session.removeAttribute("");