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

//将数据存储到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. vagrant The specified host network collides with a non-hostonly network!

    换个ip scripts\homestead.rb config.vm.network :private_network, ip: settings["ip"] ||= " ...

  2. 黄聪:AngularJS最理想开发工具WebStorm

    Aug 29, 2013 Tags: angularangular.jsangularjswebstorm Comments: 23 Comments AngularJS最理想开发工具WebStorm ...

  3. [蓝桥杯]PREV-7.历届试题_连号区间数

    问题描述 小明这些天一直在思考这样一个奇怪而有趣的问题: 在1~N的某个全排列中有多少个连号区间呢?这里所说的连号区间的定义是: 如果区间[L, R] 里的所有元素(即此排列的第L个到第R个元素)递增 ...

  4. Android之微信布局篇

    一.准备工作: 1. 下载好相关的图片: 2.创建一个名WeiChat的项目,将图片复制到res----->drawable-hdpi目录下. 二.编写代码: 1. 最终效果: 2.微信可划分为 ...

  5. go语言学习--go中的map切片

    //定义一个结构 type Car struct { Brand string Age int } func Pluck() map[int][]Car { carMap := make(map[in ...

  6. mybatis的typeHandler

    typeHandler作用: 1.传参时将javaType类型转换成jdbcType 2.结果集中ResultSet中取值时,jdbcType转换为javaType; 系统自定义的typeHandle ...

  7. XAMPP 虚拟主机配置,实现多域名访问本地项目

    XAMPP 虚拟主机配置,实现多域名访问本地项目 1.首先你既然要配置多个虚拟主机,那你肯定需要多个站点的目录文件.你可以在e盘创建 www文件夹,然后在该文件件中新建两个站点目录,假设test.co ...

  8. PHP中empty、isset和is_null的具体区别?

    1.isset()用来检测一个变量是否已声明; 2.empty()用来检测一个变量是否为空如果有如下情况返回真值: 1)空字符串 2)false 3)空数组 4)NULL 5)0 6)0.0 7)un ...

  9. 如何让大小一定的span能够包含“容不下”的内容

    overflow: hidden; text-overflow: ellipsis; width: 70px;(长度随意) 给span加上面的代码

  10. 一针见血tomcat

    一针见血tomcat 一.Tomcat各组件认知 1 Tomcat架构说明 Tomcat是一个基于JAVA的WEB容器,其实现了JAVA EE中的 Servlet 与 jsp 规范,与Nginx ap ...