• javaweb基础---- cookie


    一、保存会话数据的两种技术

    1、Cookie

      Cookie是客户端技术,程序把每个用户的数据以cookie的形式写给用户各自的浏览器。当用户使用浏览器再去访问服务器中的web资源时,就会带着各自的数据去。这样,web资源处理的就是用户各自的数据了。

    2、Session

      Session是服务器端技术,利用这个技术,服务器在运行时可以为每一个用户的浏览器创建一个其独享的session对象,由于session为用户浏览器独享,所以用户在访问服务器的web资源时,可以把各自的数据放在各自的session中,当用户再去访问服务器中的其它web资源时,其它web资源再从用户各自的session中取出数据为用户服务。

    二、Java提供的操作Cookie的API

      

      response接口也中定义了一个addCookie方法,它用于在其响应头中增加一个相应的Set-Cookie头字段。 同样,request接口中也定义了一个getCookies方法,它用于获取客户端提交的Cookie。

    三、Cookie实例

    <%@ page language="java" contentType="text/html; charset=UTF-8"
        pageEncoding="UTF-8"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>Insert title here</title>
    </head>
    <body>
    
        <%
            String username = "";
            String password = "";
    
            Cookie[] cs = request.getCookies();//获取Cookie,是一个数组,相当于一个键值对
    
            if (cs != null) {
                for (Cookie c : cs) { //当cookie不为空的时候,即有用户名和密码,循环遍历
                    
                    if ("username".equals(c.getName())) { /* 说明里面Cookie有用户名;每一个Cookie是以键值对(Name,Value)
                                                                的形式存储的,Name相当于键,Value相当于键值 */
                        username = c.getValue();
                    }
                    if ("password".equals(c.getName())) {
                        password = c.getValue();
                    }
                }
            }
        %>
    
    
    
        <form action="LoginServlet" method="post">
            <table>
                <tr>
                    <td>username:</td>
                    <td><input type="text" name="username" value="<%=username%>" /></td>
                </tr>
                <tr>
                    <td>password:</td>
                    <td><input type="text" name="password" value="<%=password%>" /></td>
                </tr>
                <tr>
                    <td colspan="2">记住密码:<input type="checkbox" name="rememberme"
                        value="do" /></td>
                </tr>
                <tr>
                    <td colspan="2"><input type="submit" value="提交" /></td>
                </tr>
            </table>
        </form>
    </body>
    </html>
    package com.hanqi.servlet;
    
    import java.io.IOException;
    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;
    
    /**
     * Servlet implementation class LoginServlet
     */
    @WebServlet("/LoginServlet")
    public class LoginServlet extends HttpServlet {
        private static final long serialVersionUID = 1L;
    
        /**
         * @see HttpServlet#HttpServlet()
         */
        public LoginServlet() {
            super();
            // TODO Auto-generated constructor stub
        }
    
        /**
         * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse
         *      response)
         */
        protected void doGet(HttpServletRequest request, HttpServletResponse response)
                throws ServletException, IOException {
            String username = request.getParameter("username");
            String password = request.getParameter("password");
            String rememberme = request.getParameter("rememberme");
            
            
            //看看控制台上能不能接收到
            System.out.println(username);
            System.out.println(password);
            System.out.println(rememberme);
    
            if (username != null && username.trim().length() > 0 && password != null && password.trim().length() > 0) {
                if (rememberme != null && rememberme.trim().length() > 0) {
                    Cookie[] cs = request.getCookies();//先获取Cookie
                    //if (cs == null) {
                        Cookie c_username = new Cookie("username", username);// 当Cookie为空的时候,实例化一个Cookie
                        Cookie c_password = new Cookie("password", password);
    
                        c_username.setMaxAge(3600);// 设置过期时间,单位为秒
                        c_password.setMaxAge(3600);
    
                        response.addCookie(c_username);// 使用response.addCookie()添加到当前使用的浏览器里面
                        response.addCookie(c_password);
    
                        System.out.println("Cookie已经添加!");
                    //}
                }
    
                response.sendRedirect("index.jsp");
            } else {
                response.sendRedirect("fail.jsp");
            }
    
        }
    
        /**
         * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse
         *      response)
         */
        protected void doPost(HttpServletRequest request, HttpServletResponse response)
                throws ServletException, IOException {
            // TODO Auto-generated method stub
            doGet(request, response);
        }
    
    }

    这样浏览器就会自动记住上次登录的账号密码

    四、Cookie注意事项

    1. 一个Cookie只能标识一种信息,它至少含有一个标识该信息的名称(NAME)和设置值(VALUE)。
    2. 一个WEB站点可以给一个WEB浏览器发送多个Cookie,一个WEB浏览器也可以存储多个WEB站点提供的Cookie。
    3. 浏览器一般只允许存放300个Cookie,每个站点最多存放20个Cookie,每个Cookie的大小限制为4KB。
    4. 如果创建了一个cookie,并将他发送到浏览器,默认情况下它是一个会话级别的cookie(即存储在浏览器的内存中),用户退出浏览器之后即被删除。若希望浏览器将该cookie存储在磁盘上,则需要使用maxAge,并给出一个以秒为单位的时间。将最大时效设为0则是命令浏览器删除该cookie。
  • 相关阅读:
    Linux环境下安装jdk1.8(CentOS7)
    MySQL创建外键报错ERROR 3780 (HY000): Referencing column ‘user_id’ and referenced column ‘id’ in foreign key constraint ‘fk_user_id’ are incompatible.
    scrapy框架的使用
    开源《热血传奇》服务端引擎(C#编写),可以顺利进行游戏(更新编译和部署教程)
    记录一下今天刚开通的博客
    Sql Server 2005中还原整个数据库重命名问题
    第一次学开车
    转载:c#与ASP.NET中DateTime.Now函数详解
    winform进度条收藏
    今天新注册的,庆祝一下
  • 原文地址:https://www.cnblogs.com/sutao/p/7445708.html
Copyright © 2020-2023  润新知