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

//将数据存储到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. Class 泛型

    Java Class 泛型的例子说明: http://blog.chinaunix.net/uid-1911213-id-3085866.html http://blog.163.com/sir_87 ...

  2. Android Dialog.dismiss()与Activity.finish()顺序

    activity.finish() 和dialog.show() 同时调用的时候, 需要先调用dialog.dismiss() 后activity.finish() 如果先直接finish()后,再触 ...

  3. Python基础------运算符

    运算符类型 算数运算符 +   加               -    减              *    乘              /    除              %取余     ...

  4. Kafka 配置安装

    1.从官网下载安装包 http://kafka.apache.org/downloads2.上传到01虚拟机,解压3.进入安装目录下的config目录4.对server.properties进行配置 ...

  5. iframe-父子-兄弟页面相互传值(jq和js两种方法)

    参考文章: http://blog.csdn.net/u013299635/article/details/78773207 http://www.cnblogs.com/xyicheng/archi ...

  6. MongoDB复制集技术

    复制集搭建 没毛病: https://www.cnblogs.com/nicolegxt/p/6841442.html?utm_source=itdadao&utm_medium=referr ...

  7. android查看屏幕密度,分辨率的shell命令

    adb shell dumpsys window displays

  8. JS购物车编辑

    实现了:第一件商品的加减实现了:全选/全不选(使用prop而不是attr)实现了:删除(遮罩层) 未实现:第二件商品的删除未实现:小计及应付款额的初始化(写死的) 计算小数乘法时,要先乘100 < ...

  9. vs与linux的交叉编译环境搭建

    很久之前就想写一个linux服务器,但是对linux的vim编译工具又不是很熟,只能在win环境下写好代码拷贝到linux环境下编译运行,现在VS出了一个插件可以对linux代码远程在linux环境下 ...

  10. python学习笔记_week26

    note 一.CMDB -采集资产 -API -后台管理 -资产列表(CURD) -业务线列表(CURD) -用户列表(CURD) -组列表(CURD) ... ===>简单<=== 公共 ...