【302天】每日项目总结系列040(2017.12.04)

本文介绍了一个简单的Servlet实现,该实现能够处理用户的登录请求,并根据用户的选择来记住或清除用户名。通过设置Cookie的有效期来实现记住用户名的功能,登录成功后会跳转到欢迎页面,若登录失败则返回登录页面并提示错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

叨叨两句

  1. ~

记住用户名

  1. 在servlet中增加一个判断,如果客户端需要记住用户名,则新建一个cookie,有效期不为0,如果不需要了,则有效期为0
  2. 登录成功,请求转发到登录欢迎页面
  3. 登录失败,请求转发到原登录页面
package com.qq.web.servlet;

import java.io.IOException;
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.qq.bean.User;
import com.qq.service.UserService;

public class LoginServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //拿到参数
        String username = request.getParameter("username");
        String password = request.getParameter("password");
        String remeber = request.getParameter("remeber");
        //调用service层处理登录请求
        UserService userService = new UserService();
        User user = userService.doLogin(username,password);
        Cookie cookie = new Cookie("username", username);
        //检查是否需要记住用户名
        if ("on".equals(remeber)) {
            //设置cookie有效期
            cookie.setMaxAge(24*60*60);
        } else {
            //不需要则清空cookie
            //设置cookie有效期
            cookie.setMaxAge(0);
        }
        
        //设置cookie有效范围
        cookie.setPath(request.getContextPath());
        //添加cookie
        response.addCookie(cookie);
        //根据返回的user决定如何响应
        if(user != null) {
            //登录成功,重定向到欢迎页面
            System.out.println(user);
            request.setAttribute("user", user);
            request.getRequestDispatcher("/success.jsp").forward(request, response);
//            response.sendRedirect(request.getContextPath()+"/success.jsp");
        } else {
            //登录失败,请求转发到登录页面,并输出错误信息
            request.setAttribute("msg", "用户名或密码错误");
            request.getRequestDispatcher("/login.jsp").forward(request, response);
        }
    }

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doGet(request, response);
    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值