前言
许多网站都提供用户自动登陆功能,即用户第一次登陆网站,服务器将用户名和密码以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页面。
后记
复制粘贴的东西一定要仔细检查。