美文网首页
使用Filter完成自动登录的小demo

使用Filter完成自动登录的小demo

作者: 字节码 | 来源:发表于2017-02-04 11:51 被阅读442次
    Filter过滤器的概念

    Java中的Filter 并不是一个标准的Servlet ,它不能处理用户请求,也不能对客户端生成响应。 主要用于对HttpServletRequest 进行预处理,也可以对HttpServletResponse 进行后处理,是个典型的处理链。
    优点:执行过程中任何时候都可以打断,只要不执行chain.doFilter()就不会再执行后面的过滤器和请求的内容。而在实际使用时,就要特别注意过滤链的执行顺序问题

    Filter过滤器的作用描述

    在HttpServletRequest 到达Servlet 之前,拦截客户的HttpServletRequest 。
    根据需要检查HttpServletRequest ,也可以修改HttpServletRequest 头和数据。
    在HttpServletResponse 到达客户端之前,拦截HttpServletResponse 。
    根据需要检查HttpServletResponse ,可以修改HttpServletResponse 头和数据。

    注意:一个资源有可能被多个过滤器匹配成功,多个过滤器的执行顺序是按照web.xml中filter-mapping的顺序执行的

    Demo演示

    需求: 登录时,勾选自动登录,若登录成功,当关闭浏览器时,下次访问网站的时候完成自动登录操作。

    需要使用的服务端技术:FilterCookieSession

    步骤:
    1.创建数据库和表

    CREATE DATABASE mydb1;
    CREATE TABLE `user` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `username` varchar(20) DEFAULT NULL,
      `password` varchar(20) DEFAULT NULL,
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=latin1
    insert into user values(null, 'sey', '123');
    

    2.创建java web项目:
    导入jar包 、工具类、 配置文件

    3.在web项目中新建一个登录界面login.jsp用于测试登录

    4.创建LoginServlet,当用户点击登录时,提交表单到LoginServlet,完成登录操作

    获取表单数据中的 用户名和密码
    调用service层 完成登录操作 返回User
    根据service层返回的user对象结果是否存在,进行分发转向
    若用户为null,则请求转发到登录界面, 若用户存在,则跳转到success界面,将用户放入session中
    判断用户是否勾选了自动登录,若勾选了需要将用户名和密码放入到cookie中,写回客户端
    请求重定向

    public class LoginServlet extends HttpServlet {
        private static final long serialVersionUID = 1L;
    
        protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            
            // 1.设置编码
            request.setCharacterEncoding("UTF-8");
            
            // 2.获取表单数据 用户名和密码
            String username = request.getParameter("username");
            String password = request.getParameter("password");
            
            // 3.调用service层 完成登录操作 返回User
            User user = null;
            try {
                user = new UserServiceImp().login(username, password);
            } catch (Exception e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            
            // 4.分发转向
            // 根据service层返回的user对象是否存在,进行分发转向
            if (user == null) {
                // 若用户为null,则请求转发到登录界面
                request.setAttribute("msg", "用户名或密码错误");
                request.getRequestDispatcher("/login.jsp").forward(request, response);
                return;
            } else {
                // 若用户存在,则跳转到success界面
                
                // 将用户放入session中
                request.getSession().setAttribute("user", user);
                
                // 判断用户是否勾选了自动登录,若勾选了需要将用户名和密码放入到cookie中,写回客户端
                if (Constant.IS_AUTO_LOGIN.equals(request.getParameter("autoLogin"))) {
                    // 创建cookie,并将用户名和密码拼接到cookie中
                    Cookie ck = new Cookie("autoLogin", username+"-"+password);
                    ck.setMaxAge(3600);
                    ck.setPath(request.getContextPath()+"/");
                    response.addCookie(ck);
                }
                
                // 请求重定向
                response.sendRedirect(request.getContextPath()+"/success.jsp");
                
            }
        }
    
    
        protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            
            doGet(request, response);
        }
    
    }
    

    5.创建AutoLoginFilter,当用户勾选自动登录选项时,再次进入页面,完成自动登录操作

    再次访问网站的时候
    通过过滤器拦截任意请求
    首先判断session中是否有user,若没有 并且访问的路径不是和登录注册相关的时候,才去获取指定的cookie
    判断有无指定的cookie,如果有cookie,获取用户名和密码
    调用service完成登录操作,返回user
    当user不为空的时候将user放入session中.
    注意:自动登录只需要登录一次:当session中没有用户的时候
    访问有些资源是不需要自动登录的(和登录还有注册相关的资源)

    public class AutoLoginFilter implements Filter {
    
        @Override
        public void destroy() {
            // TODO Auto-generated method stub
    
        }
    
        @Override
        public void doFilter(ServletRequest arg0, ServletResponse arg1, FilterChain arg2)
                throws IOException, ServletException {
            
            HttpServletRequest request = (HttpServletRequest) arg0;
            
            // 完成自动登录:
            // 取出session中保存的登录用户
            User user = (User) request.getSession().getAttribute("user");
            // 判断登录user是否为null
            if (user == null) { // 没有user则需要自动登录
                
                // 判断访问的资源是否和登录注册相关,如果相关则不需要自动登录
                String requestURI = request.getRequestURI();
                if (!requestURI.contains("/login")) {
                    // 不与登录相关,完成自动登录
                    
                    // 获取自动登录的cookie
                    Cookie ck = CookieUtils.getCookieByName("autoLogin", request.getCookies());
                    if (ck != null) {
                        // 取出用户名和密码
                        String username = ck.getValue().split("-")[0];
                        String password = ck.getValue().split("-")[1];
                        // 调用service层完成登录
                        try {
                            user = new UserServiceImp().login(username, password);
                        } catch (Exception e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        }
                        
                        // 如果user存在,则键user放入到session中
                        if (user != null) {
                            request.getSession().setAttribute("user", user);
                        }
                    }
                }
            }
            
            // 放行
            arg2.doFilter(arg0, arg1);
        }
    
        @Override
        public void init(FilterConfig arg0) throws ServletException {
            // TODO Auto-generated method stub
    
        }
    
    }
    
    

    相关文章

      网友评论

          本文标题:使用Filter完成自动登录的小demo

          本文链接:https://www.haomeiwen.com/subject/oiejittx.html