用cookie实现自动登录

本文介绍了如何使用Cookie来实现在用户首次登录后,能够自动完成下次登录的功能。重点讲解了在登录页面设置Cookie的过程,并提及了Servlet在其中的作用。

今天学习了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>
    <%//获取用户名和密码cookie,判断cookie是否为空,为空的情况就是第一次登录,跳到登录页面,不为空就直接跳转到登陆后的页面。
        String name=null;
        String password=null;
        Cookie[] cookies=request.getCookies();
        if(cookies!=null){
            for(Cookie cookie:cookies){
                if(cookie.getName().equals("username")){
                    name=cookie.getValue();
                }
                if(cookie.getName().equals("pwd")){
                    password=cookie.getValue();
                }
            }
            if(name!=null&&password!=null){
                response.sendRedirect("LoginServlet?username="+name+"&pwd="+password);
            }
        }

    %>
    <h1>欢迎来到动物园</h1>
    <form action="<%=request.getContextPath()%>/LoginServlet" method="get">
        <p>请输入口令:<input type="text" name="username"></p>
        <p>请输入密码:<input type="password" name="pwd"></p>
         <p><input type="checkbox" name="box" value="ck">自动登录</p>
        <p><input type="submit" value="欢迎进入"></p>
    </form>
</body>
</html>

下面是servlet

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        接收请求参数的值
        String username=request.getParameter("username");
        String password=request.getParameter("pwd");
                if(username.equals("yyy")&&password.equals("123")) {
                    //如果没有选中自动登录,则要输入账号登录,否则就会执行cookie,实现自动登录
                    if(request.getParameter("box")==null) {
                        request.getRequestDispatcher("SearchAllServlet").forward(request, response);
                    }else {

                    Cookie name=new Cookie("username", username);
                    Cookie pwd=new Cookie("pwd", password);
                    response.addCookie(name);
                    response.addCookie(pwd);
                    name.setMaxAge(60*60);
                    pwd.setMaxAge(60*60);
                    request.getRequestDispatcher("SearchAllServlet").forward(request, response);
                }
                }
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值