MVC-使用Servlet验证用户是否登陆

比如网站提供Hero查询服务,但是前提是用户要登录过才能使用。 
如果用户登陆过了,访问listHero,就让用户正常访问,否则就跳转到登陆界面。 
这是非常常见的场景,通过使用 session 来实现这个功能。 
在处理登录的loginServlet 中使用将用户名保存在session中。 
在HeroListServlet 中查看session中是否为空。如果为空,就表示用户没有登陆过,就跳转到登陆页面

  • 在LoginServlet 把验证成功的用户加入到 Session

    如果用户输入正确的账号密码,就跳转到 listHero,并且把用户名以"userName"放进session

    如果用户输入错误的账号密码,就跳转到 login.html,让用户重新登陆
    import java.io.IOException;
     
    import javax.servlet.ServletException;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
     
    public class LoginServlet extends HttpServlet {
     
        private static final long serialVersionUID = 1L;
     
        protected void service(HttpServletRequest request, HttpServletResponse response)
                throws ServletException, IOException {
            String name = request.getParameter("name");
            String password = request.getParameter("password");
     
            if ("admin".equals(name) && "123".equals(password)) {
                request.getSession().setAttribute("userName", name);
                response.sendRedirect("listHero");
            } else {
                response.sendRedirect("login.html");
            }
     
        }
    }
  • 在HeroListServlet判断Session中是否有数据

    String userName = (String) request.getSession().getAttribute("userName");
       if (null == userName) {
       response.sendRedirect("login.html");
       return;
    }
    从session中取出userName,如果是空,就表示用户没有登录,或者登录已经超过了30分钟。 客户端跳转到login.html,让用户重新登陆
    package servlet;
     
    import java.io.IOException;
    import java.util.List;
     
    import javax.servlet.ServletException;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
     
    import bean.Hero;
    import dao.HeroDAO;
     
    public class HeroListServlet extends HttpServlet {
     
        protected void service(HttpServletRequest request, HttpServletResponse response)
                throws ServletException, IOException {
     
            String userName = (String) request.getSession().getAttribute("userName");
            if (null == userName) {
                response.sendRedirect("login.html");
                return;
            }
     
            int start = 0;
            int count = 5;
     
            try {
                start = Integer.parseInt(request.getParameter("start"));
            } catch (NumberFormatException e) {
                // 当浏览器没有传参数start时
            }
     
            int next = start + count;
            int pre = start - count;
     
            int total = new HeroDAO().getTotal();
     
            int last;
            if (0 == total % count)
                last = total - count;
            else
                last = total - total % count;
     
            pre = pre < 0 ? 0 : pre;
            next = next > last ? last : next;
     
            request.setAttribute("next", next);
            request.setAttribute("pre", pre);
            request.setAttribute("last", last);
     
            List<Hero> heros = new HeroDAO().list(start, count);
            request.setAttribute("heros", heros);
     
            request.getRequestDispatcher("listHero.jsp").forward(request, response);
     
        }
    }


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用JSP、Servlet和JavaBean的MVC开发模式完成登录验证的步骤如下: 1. 创建一个JSP页面,用于展示登录表单给用户填写。表单包含用户名和密码输入框以及提交按钮。用户填写完表单后,点击提交按钮进行登录验证。 2. 创建一个Servlet,用于处理登录表单的提交请求。在Servlet中,获取用户输入的用户名和密码,并将其传递给JavaBean进行验证。 3. 创建一个JavaBean,用于对用户输入的用户名和密码进行验证。在JavaBean中,可以连接数据库,查询用户表,并验证用户名和密码是否匹配。 4. 在Servlet中,根据JavaBean的验证结果,决定用户登录成功与否。如果验证通过,可以进行一些额外操作,如将用户的登录信息保存到Session中,然后重定向到登录成功的页面。如果验证不通过,可以返回错误信息给用户,并重新展示登录表单。 5. 在JSP页面中,可以根据Servlet返回的结果,显示登录成功或失败的提示信息。如果登录失败,可以展示错误信息,并重新显示登录表单,以便用户重新填写。 使用MVC开发模式可以将不同的功能进行解耦,使得代码结构清晰、可维护性强。JSP负责视图的展示,Servlet负责控制流程的处理,JavaBean负责业务逻辑的实现。这样的分层结构提高了代码的可重用性和可扩展性。同时,使用MVC开发模式还可以更好地实现前后端分离,使得前端和后端的开发可以相对独立进行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值