//反复实验的时候注意数据库数据的更新

//将数据存储到cookie里面

protected void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
     request.setCharacterEncoding("utf-8");
     HttpSession se = request.getSession();
     String username = request.getParameter("username");
     String password = request.getParameter("password");
     UserService ser=new UserService();
     User1 user=null;
     try {
        user=ser.login(username,password);
    } catch (SQLException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
     System.out.println("您好");
     if(user!=null){
         String autoLogin=request.getParameter("autoLogin");
         if(autoLogin!=null){
             System.out.println("0");
             Cookie cookie_username=new Cookie("cookie_username",username);
             Cookie cookie_password=new Cookie("cookie_password",password);
             System.out.println(username);
             System.out.println(password);
             //设置cookie持续化时间
             cookie_username.setMaxAge(60*10);
             cookie_password.setMaxAge(60*10);
             //设置路径
             cookie_username.setPath(request.getContextPath());
             cookie_password.setPath(request.getContextPath());
             //发送cookie
             response.addCookie(cookie_username);
             response.addCookie(cookie_password);
             System.out.println("0.1");
         }
         //非自动登录部分
         se.setAttribute("user", user);
         response.sendRedirect(request.getContextPath());
     }else{
         request.setAttribute("logininfo", "用户名密码错误");
         request.getRequestDispatcher("login.jsp").forward(request, response);
     }  
    }

//拦截器部分代码

public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
        HttpServletRequest req=(HttpServletRequest)request;
        HttpServletResponse resp=(HttpServletResponse)response;
           HttpSession session = req.getSession();
           String cookie_username=null;
           String cookie_password=null;
           System.out.println("1");
           Cookie[] cookies = req.getCookies();
           if(cookies!=null){
                   for(Cookie cookie:cookies){
                      
                       if("cookie_username".equals(cookie.getName())){
                           cookie_username=cookie.getValue();
                       }
                       if("cookie_password".equals(cookie.getName())){
                           cookie_password=cookie.getValue();
                       }
                   }
           }
           System.out.println("3");
           
           if(cookie_username!=null&&cookie_password!=null){
               UserService ser = new UserService();
               User1 user=null;
               try {
                user=ser.login(cookie_username, cookie_password);
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
               session.setAttribute("user", user);
               if(user!=null){
                   request.getRequestDispatcher("index.jsp").forward(req,resp);
               }
               
               
           }
            
            chain.doFilter(req, resp);
            System.out.println("5");
    }

//web.xml的配置

<filter>
    <display-name>Myservlet2</display-name>
    <filter-name>Myservlet2</filter-name>
    <filter-class>cn.jy.web.Myservlet2</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>Myservlet2</filter-name>
    <url-pattern>/*</url-pattern>                              //注意  /*
  </filter-mapping>

自动登录(过滤器filter的应用)的更多相关文章

  1. 实现自动登录:Filter 实现思路和方式

    当你勾选(记住登录状态),用cookie保存用户名和密码.不勾选,cookie失效. 所有的页面都要经过autoLoginFilter.java 的过滤器,在这类中,必须要判断cookies不为nul ...

  2. JavaWeb 后端 <十二> 之 过滤器 filter 乱码、不缓存、脏话、标记、自动登录、全站压缩过滤器

    一.过滤器是什么?有什么? 1.过滤器属于Servlet规范,从2.3版本就开始有了. 2.过滤器就是对访问的内容进行筛选(拦截).利用过滤器对请求和响应进行过滤

  3. Filter自动登录

    Dao层略过 Domain略过 Service层过 Web层 Select逻辑 获取表单数据,Web-service--Dao返回用户信息 如果返回不为null否则,重定向到登录页面.则判断用户是否勾 ...

  4. Filter应用之-自动登录

    自动登录,是为了帮助用户多次使用这个网页时,不用再次输入用户名和密码就可以登录. 是指用户将用户的登录信息,人,保存到本地的文件中Cookie中. Name,value – 声明时 new Cooki ...

  5. cookies session filter 自动登录

    webxml <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi=" ...

  6. 二十 Filter&自动登录功能

    Filter过滤器 过滤器,其实就是对客户端发出来的请求进行过滤,浏览器发出,然后服务器用Servelt处理.在中间就可以过滤,起到的是拦截的作用. 不仅仅作用于客户端请求,而且过滤服务器响应 作用: ...

  7. JavaWeb学习记录总结(二十九)--Servlet\Session\Cookie\Filter实现自动登录和记住密码

    一.Servlet package autologin.servlet.login; import java.io.IOException;import java.security.MessageDi ...

  8. 过滤器Filter的使用(以登录为例子)

    使用过滤器步骤: (1)在web.xml文件中添加过滤器(以下例子是过滤多个请求) <!-- 用户登录过滤 --> <filter> <filter-name>lo ...

  9. JavaWeb 使用Filter实现自动登录

    思路 使用cookie存储账号.密码,使用Filter拦截,从cookie中取出账号.密码.若用户要注销|登出.不再想使用自动登录,将cookie的有效期设置为0即可. 浏览器可以查看Cookie,不 ...

随机推荐

  1. nginx gzip配置

    参考: https://docs.nginx.com/nginx/admin-guide/web-server/compression/ server { gzip on;    gzip_types ...

  2. js延迟

    function sleep(numberMillis) { var now = new Date(); var exitTime = now.getTime() + numberMillis; wh ...

  3. Linux查看端口占用情况并释放端口占用

    1.netstat -tunlp:查看所有tcp/udp端口占用及进程相关信息 2.netstat -tln | grep 端口号:查看特定端口占用情况 3.kill -9 进程ID(PID):释放指 ...

  4. Entity Framework Code first 可能会导致循环或多个级联路径.

    用code first映射数据库报错 Introducing FOREIGN KEY constraint 'FK_dbo.Roles_dbo.SubSystems_SubSystemID' on t ...

  5. Grafana+Prometheus打造springboot监控平台

    1. 环境 springboot 1.5.10.RELEASE Grafana 5.4.2 Prometheus 2.6.0 jdk 1.8 2.通过micrometer与springboot应用和p ...

  6. python 如何把小数变成百分数格式

    1. 数据样本 ,valid_rate,homework_rate,inter_rate,playback_rate,zhujiang_good_comment5_rate,fudao_good_co ...

  7. Django之前后端交互使用ajax的方式

    1. 在项目中前后端数据相互是一种常态, 前后端交互使用的是ajax请求和form表单的请求两种方式" ajax与form表单的区别在于: form 是整个页面刷新提交的,  但是ajax ...

  8. background url base64

    各自含义:data: ----获取数据类型名称image/gif; -----指数据类型名称base64 -----指编码模式AAAAA ------指编码以后的结果. background-imag ...

  9. ODPS SQL <for 数据操作语言DML>

    基本操作: 查询: SELECT [ALL | DISTINCT] select_expr, select_expr, ... FROM table_reference [WHERE where_co ...

  10. JavaScript: For , For/in , For/of

    For: define: The for statement can customize how many times you want to execute code Grammar: for (c ...