用户登陆与用户退出流程的实现(java)

前置知识点
前端使用技术jsp,servlet,jQuery,bootstrap,
后端采用java语言编写
数据库采用mysql8.0.30
用到的数据:
数据库表:在这里插入图片描述

一、普通登陆

在这里插入图片描述

实现登陆流程步骤

实现登陆流程需要前端后端共同实现

(一)前端

概括:准备一个表单,表单中设置隐藏域actionName=userLogin,当表单提交时将隐藏域一同提交、服务器端用之来判断前端是什么操作行为。

1、整体思路

前端实现
1. 添加表单,设置表单属性
action=“user” method=“post” id=“loginForm”
2. 设置表单元素的那么属性值,修改id属性值(首字母改小写)
设置文本框和密码框的那么属性值
设置复选框的那么属性值和value属性值(如果复选框未选中,在获取不到value属性值)
设置隐藏域,传递用户行为 (name=“actionName” value=“login”)
3. 在 config.js 文件中,添加按钮的点击事件绑定的函数 checkLogin()
表单校验
1. 获取表单元素的值(姓名、密码)
2. 判断元素的值是否为空(引入util.js文件)
如果为空,设置提示信息 (通过设置span标签),并return
3. 如果不为空,则提交表单

2、代码实现

login.jsp

<form action="user" method="post" id="loginForm">
                    <%-- actionName表示用户行为,通过这个参数可以在UserServlet中判断用户当前想要操作的功能 --%>
                    <input type="hidden" name="actionName" value="login"/>
                    <input type="text" class="user yahei16" id="userName" name="userName" value="${resultInfo.result.uname}" /><br /><br />
                    <input type="password" class="pwd yahei16" id="userPwd" name="userPwd" value="${resultInfo.result.upwd}" /><br /><br />
                    <input name="rem" type="checkbox" value="1"  class="inputcheckbox"/> <label>记住我</label>&nbsp; &nbsp;
                    <span id="msg" style="color: red;font-size: 12px;">${resultInfo.msg}</span><br /><br />
                    <input type="button" class="log jc yahei16" value="登 录" οnclick="checkLogin()" />&nbsp; &nbsp; &nbsp; <input type="reset" value="取 消" class="reg jc yahei18" />
                    
</form>

(二)后端

概括:从前端获取参数,后端分层处理优先通过用户名验证查询,返回处理信息给前端
后端实现

1、整体思路:
1. 获取参数 (姓名、密码)
2. 参数的非空校验  (ResultInfo的封装类,用来封装响应结果  状态码、提示信息、返回的对象)
    如果为空
        设置ResultInfo对象的状态码和提示信息
        将ResultInfo对象设置request作用域中
        请求转发跳转到登录页面
        return
3. 如果不为空,通过用户名查询用户对象
4. 判断用户对象是否为空
    如果为空
        设置ResultInfo对象的状态码和提示信息
        将ResultInfo对象设置request作用域中
        请求转发跳转到登录页面
        return
5. 如果用户对象不为空,将数据库中查询到的用户对象的密码与前台传递的密码作比较 (将密码加密后再比较)
    如果密码不正确
        设置ResultInfo对象的状态码和提示信息
        将ResultInfo对象设置request作用域中
        请求转发跳转到登录页面
        return
6. 如果密码正确
    将用户信息存到session作用域中
    判断用户是否选择记住密码(rem的值是1)
        如果是,将用户姓名与密码存到cookie中,设置失效时间,并响应给客户端
        如果否,清空原有的cookie对象
    重定向跳转到index页面
2、分层思想:
Web层:(控制层:接收参数、响应数据)
    1. 获取参数 (姓名、密码)
    2. 调用Service层的方法,返回ResultInfo对象
    3. 判断是否登录成功
        如果失败
            将resultInfo对象设置到request作用域中
            请求转发跳转到登录页面
        如果成功
            将用户信息设置到session作用域中
            判断用户是否选择记住密码(rem的值是1)
                如果是,将用户姓名与密码存到cookie中,设置失效时间,并响应给客户端
                如果否,清空原有的cookie对象
            重定向跳转到index页面
Service层:(业务逻辑层:参数判断、业务逻辑处理)
    1. 判断参数是否为空
        如果为空
            设置ResultInfo对象的状态码和提示信息
            返回resultInfo对象
    2. 如果不为空,通过用户名查询用户对象
    3. 判断用户对象是否为空
            如果为空
                设置ResultInfo对象的状态码和提示信息
                返回resultInfo对象
    4. 如果用户对象不为空,将数据库中查询到的用户对象的密码与前台传递的密码作比较 (将密码加密后再比较)
           如果密码不正确
                设置ResultInfo对象的状态码和提示信息
                返回resultInfo对象
    5. 如果密码正确
        设置ResultInfo对象的状态码和提示信息
    6. 返回resultInfo对象


Dao层:(数据访问层:数据库中的增删改查操作)
    通过用户名查询用户对象, 返回用户对象
        1. 获取数据库连接
        2. 定义sql语句
        3. 预编译
        4. 设置参数
        5. 执行查询,返回结果集
        6. 判断并分析结果集
        7. 关闭资源
3、代码实现

         private void userLogin(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

        // 1. 获取参数 (姓名、密码)
        String userName = request.getParameter("userName");
        String userPwd = request.getParameter("userPwd");

        // 2. 调用Service层的方法,返回ResultInfo对象
        ResultInfo<User> resultInfo = userService.userLogin(userName, userPwd);

        // 3. 判断是否登录成功
        if (resultInfo.getCode() == 1) { // 如果成功
            //  将用户信息设置到session作用域中
            request.getSession().setAttribute("user", resultInfo.getResult());
            //  判断用户是否选择记住密码(rem的值是1)
            String rem = request.getParameter("rem");
            // 如果是,将用户姓名与密码存到cookie中,设置失效时间,并响应给客户端
            if ("1".equals(rem)) {
                 // 得到Cookie对象
                Cookie cookie = new Cookie("user",userName +"-"+userPwd);
                // 设置失效时间(3天)
                cookie.setMaxAge(3*24*60*60);
                // 响应给客户端
                response.addCookie(cookie);
            } else {
                // 如果否,清空原有的cookie对象
                Cookie cookie = new Cookie("user", null);
                // 删除cookie,设置maxage为0
                cookie.setMaxAge(0);
                // 响应给客户端
                response.addCookie(cookie);
            }
            // 重定向跳转到index页面
            response.sendRedirect("index");

        } else { // 失败
            // 将resultInfo对象设置到request作用域中
            request.setAttribute("resultInfo", resultInfo);
            // 请求转发跳转到登录页面
            request.getRequestDispatcher("login.jsp").forward(request, response);
        }

    }

二、非法访问拦截登陆

1、整体思路

非法访问拦截
拦截的资源:
所有资源 /*

	需要被放行的资源:
		1、指定页面,放行 (用户无需登录即可访问的页面;例如:登录页面login.jsp、注册页面register.jsp等)
		2、静态资源,放行 (存放在statics目录下的资源;例如:js、css、images等)
		3、指定行为,放行 (用户无需登录即可执行的操作;例如:登录操作user?actionName=login、注册操作等)
		4、登录状态,放行 (判断session作用域中是否存在用户信息;存在就放行,不存在,就拦截跳转到登录页面)

三、免登录

1、整体思路
免登录(自动登录)
	通过Cookie和Session对象实现
	什么时候使用免登录:
	    当用户处于未登录状态,且去请求需要登录才能访问的资源时,调用自动登录功能
	目的:
		让用户处于登录状态(自动调用登录方法)
	实现:
		从Cookie对象中获取用户的姓名与密码,自动执行登录操作
			1、获取cookie数组
			2、判断cookie数组
			3、遍历cookie数组,获取指定的cookie对象   (name为user的cookie对象)
			4、得到指定cookie对象的value    (姓名与密码:userName-userPwd)
			5、通过split()方法将value字符串转换成数组
			6、从数组中别得到姓名和密码
			7、请求转发跳转到登录操作    user?actionName=login&userName=姓名&userPwd=密码
			return;

四、用户退出

在index.jsp中

前端

    设置超链接的请求地址  user?actionName=logout

后台

    1. 销毁Session对象
    2. 删除Cookie对象
    3. 重定向跳转到登录页面
3.代码实现
private void userLogOut(HttpServletRequest request, HttpServletResponse response) throws IOException {
        // 1. 销毁Session对象
        request.getSession().invalidate();
        // 2. 删除Cookie对象
        Cookie cookie = new Cookie("user", null);
        cookie.setMaxAge(0); // 设置0,表示删除cookie
        response.addCookie(cookie);
        // 3. 重定向跳转到登录页面
        response.sendRedirect("login.jsp");
    }

  • 2
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值