记录一次写CooKie自动登陆实例遇到的问题(大马虎就是我)

前言

许多网站都提供用户自动登陆功能,即用户第一次登陆网站,服务器将用户名和密码以Cookie形式发送到客户端。当客户下次再访问该网站时,浏览器自动将Cookie文件中的用户名和密码一起发送到服务器,服务器从Cookie中取出信息,实现自动登陆。

login.jsp

<%@ page contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<html>
<head><title>登录页面</title></head>
<body>
${sessionScope.message}<br>
<form action="CheckUserServlet" method="post">
        用户名:<input type="text" name="username"/><br>
        密码:<input type="password" name="password"/><br>
        <input type="checkbox" name = "check" value="check" />自动登陆<br>
        <input type="submit" value="提交" />
        <input type="reset" value="重置"/>


</form>
</body>
</html>


注意这里的name=username和password,我是在这里出错,我当时直接套的一个程序的登陆界面,和我之后CheckUserServlet.java中的不符,从而导致空指针异常java.lang.NullPointerException。
在这里插入图片描述

welcome.jsp

<%@ page contentType="text/html;charset=UTF-8" %>
<html><title>欢迎页面</title><body>
欢迎您!${sessionScope.message}
</body>
</html>

CheckUserServlet.java

package com.demo;
import java.io.IOException;
import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.annotation.WebServlet;

@WebServlet("/CheckUserServlet")
public class CheckUserServlet extends javax.servlet.http.HttpServlet {
    String message = null;
    public void doGet(HttpServletRequest request,
                         HttpServletResponse response)
            throws ServletException, IOException {
        response.setContentType("text/html;charset=utf-8");
        String value1 = "",value2="";
        Cookie cookie = null;
        Cookie[] cookies = request.getCookies();
        if (cookies!=null){
            for(int i = 0;i<cookies.length;i++){
                cookie = cookies[i];
                if(cookie.getName().equals("username"))
                    value1 = cookie.getValue();
                if(cookie.getName().equals("password"))
                    value2 = cookie.getValue();
            }
            if(value1.equals("admin")&&value2.equals("admin")){
                message = "欢迎您!"+value1+"再次登录该页面!";
                request.getSession().setAttribute("message", message);
                response.sendRedirect("welcome.jsp");
            }else{
                response.sendRedirect("login.jsp");
            }
        }else{
            response.sendRedirect("login.jsp");
        }
    }
    public void doPost(HttpServletRequest request,
                          HttpServletResponse response)
            throws ServletException, IOException{
        response.setContentType("text/html;charset=utf-8");
        String username;
        username = request.getParameter("username").trim();
        String password;
        password = request.getParameter("password").trim();
        if(!username.equals("admin") || !password.equals("admin")){
            message = "用户名或口令不正确,请重试!";
            request.getSession().setAttribute("message",message);
            response.sendRedirect("login.jsp");
        }else{
            // 如果用户选中了“自动登录”复选框,向浏览器发送2个Cookie
            if((request.getParameter("check")!=null) &&
                    (request.getParameter("check").equals("check"))){
                Cookie nameCookie = new Cookie("username", username);
                Cookie pswdCookie = new Cookie("password", password);
                nameCookie.setMaxAge(60*60);
                pswdCookie.setMaxAge(60*60);
                response.addCookie(nameCookie);
                response.addCookie(pswdCookie);
            }
            message = "你已成功登录!";
            request.getSession().setAttribute("message",message);
            response.sendRedirect("welcome.jsp");
        }
    }
}


问题就是在
String username;
username = request.getParameter(“username”).trim();
String password;
password = request.getParameter(“password”).trim();
我这里写的是username,login.jsp中开始写的是userName,复制粘贴害人啊。

以GET方法访问CheckUserServlet,当Servlet将响应重定向到llogin.jsp页面。该页面中如果用户输入了正确的用户名和口令,且选中“自动登陆”选框。

  // 如果用户选中了“自动登录”复选框,向浏览器发送2个Cookie
            if((request.getParameter("check")!=null) &&
                    (request.getParameter("check").equals("check"))){
                Cookie nameCookie = new Cookie("username", username);
                Cookie pswdCookie = new Cookie("password", password);

单击提交,会发送POST请求由doPost()处理。在该方法中使用用户名和口令创建两个Cookie对象并发送到客户端。
之后再发送GET请求,Servlet将从Cookie中检索出用户名和口令,并验证通过后将响应重定向到welcome.jsp页面。
在这里插入图片描述
在这里插入图片描述

后记

复制粘贴的东西一定要仔细检查。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值