在servlet里对查询结果进行分析
如果用户不存在,登录失败,返回登录页面,并给出错误提示
如果登录成功,查看用户是否勾选了自动登录,
如果选了,将用户用cookie写回客户端保存
登录成功后将登录信息保存到session
代码
import java.io.IOException;
import java.sql.SQLException;
import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.itheima.login.domain.User;
import com.itheima.login.service.UserService;
public class LoginServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
try {
//获取用户名和密码
String username = request.getParameter("username");
String password=request.getParameter("password");
//调用业务层执行登陆
UserService service = new UserService();
User user= service.login(username,password);
//登录失败
if (user==null){
//转发错误信息到登录页面
request.setAttribute("msg","用户名或密码错误");
request.getRequestDispatcher("/login.jsp").forward(request, response);
}else{
//登陆成功
//获取用户是否勾选了自动登录
String autologin=request.getParameter("autologin");
//如果用户勾选了自动登录,把用户名和密码以cookie的形式写回客户端
if("auto".equals(autologin)){
Cookie cookieUsr=new Cookie("username",username);
cookieUsr.setPath("/");
cookieUsr.setMaxAge(60*60*24*7);
Cookie cookiePsw=new Cookie("password", password);
cookiePsw.setPath("/");
cookiePsw.setMaxAge(60*60*24*7);
response.addCookie(cookiePsw);
response.addCookie(cookieUsr);
}
//登录成功以后,把user对象存储到session中
request.getSession().setAttribute("usr", user);
request.getRequestDispatcher("/welcome.jsp").forward(request, response);
}} catch (SQLException e) {
e.printStackTrace();
}
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
}