Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 329|回复: 0

【JAVAWEB学习笔记】24_filter实现自动登录和解决全局的编码问题

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-5-31 14:56:41 | 显示全部楼层 |阅读模式

    过滤器Filter

    学习目标

    案例-自动登录

    案例-解决全局的编码

     

    一、过滤器Filter

    1.filter的简介

    filter是对客户端访问资源的过滤,符合条件放行,不符合条件不放行,并且可以对目标资源访问前后进行逻辑处理。

     

    2.快速入门

    步骤:

    1)编写一个过滤器的类实现Filter接口

    2)实现接口中尚未实现的方法(着重实现doFilter方法)

    3)在web.xml中进行配置(主要是配置要对哪些资源进行过滤)

     

    3.Filter的API详解

    (1)filter生命周期及其与生命周期相关的方法

    Filter接口有三个方法,并且这个三个都是与Filter的生命相关的方法

    init(Filterconfig):代表filter对象初始化方法 filter对象创建时执行

    doFilter(ServletRequest,ServletResponse,FilterCha):代表filter执行过滤的核心方法,如果某资源在已经被配置到这个filter进行过滤的话,那么每次访问这个资源都会执行doFilter方法

    destory():代表是filter销毁方法 当filter对象销毁时执行该方法

     

    Filter对象的生命周期:

    Filter何时创建:服务器启动时就创建该filter对象

    Filter何时销毁:服务器关闭时filter销毁

     

    (2)Filter的AP详解

    1)init(FilterConfig)

    其中参数config代表 该Filter对象的配置信息的对象,内部封装是该filter的配置信息。

    2)destory()方法

    filter对象销毁时执行

    3)doFilter方法

    doFilter(ServletRequest,ServletResponse,FilterChain)

    其中的参数:

    ServletRequest/ServletResponse:每次在执行doFilter方法时 web容器负责创建一个request和一个response对象作为doFilter的参数传递进来。该request个该response就是在访问目标资源的service方法时的request和response。

    FilterChain:过滤器链对象,通过该对象的doFilter方法可以放行该请求

    图filter的访问流程1: 

    图filter的访问流程2:

     

    4.Filter的配置

    注意:flter是按照filter-mapping的顺序来执行的

     

    url-pattern配置时

    1)完全匹配  /sertvle1

    2)目录匹配  /aaa/bbb/* ----最多的

    /user/*:访问前台的资源进入此过滤器

    /admin/*:访问后台的资源时执行此过滤器

    3)扩展名匹配  *.abc  *.jsp

     

    注意:url-pattern可以使用servlet-name替代,也可以混用

     

     

    dispatcher:访问的方式(了解)

    REQUEST:默认值,代表直接访问某个资源时执行filter

    FORWARD:转发时才执行filter

    INCLUDE: 包含资源时执行filter (引用其他资源)

    ERROR:发生错误时 进行跳转是执行filter

     

    总结Filter的作用?

    1)公共代码的提取,例如request.setCharacterEncoding(“UTF-8”)

    2)可以对request和response中的方法进行增强(装饰者模式/动态代理)

    3)进行权限控制

     

    二、案例

    1.自动登录(核心代码)

     

    public class AutoLoginFilter implements Filter{
    
     
    
       @Override
    
       public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
    
             throws IOException, ServletException {
    
         
    
          HttpServletRequest req = (HttpServletRequest) request;
    
          HttpServletResponse resp = (HttpServletResponse) response;
    
          HttpSession session = req.getSession();
    
         
    
          //获得cookie中用户名和密码 进行登录的操作
    
          //定义cookie_username
    
          String cookie_username = null;
    
          //定义cookie_password
    
          String cookie_password = null;
    
          //获得cookie
    
          Cookie[] cookies = req.getCookies();
    
          if(cookies!=null){
    
             for(Cookie cookie : cookies){
    
                //获得名字是cookie_username和cookie_password
    
                if("cookie_username".equals(cookie.getName())){
    
                    cookie_username = cookie.getValue();
    
                    //恢复中文用户名
    
                    cookie_username = URLDecoder.decode(cookie_username, "UTF-8");
    
                }
    
                if("cookie_password".equals(cookie.getName())){
    
                    cookie_password = cookie.getValue();
    
                }
    
             }
    
          }
    
          //判断username和password是否是null
    
          if(cookie_username!=null&&cookie_password!=null){
    
             //登录的代码
    
             UserService service = new UserService();
    
             User user = null;
    
             try {
    
                user = service.login(cookie_username,cookie_password);
    
             } catch (SQLException e) {
    
                e.printStackTrace();
    
             }
    
             //将登录的用户的user对象存到session中
    
             session.setAttribute("user", user);
    
          }
    
          //放行
    
          chain.doFilter(req, resp);
    
       }
    
    
       @Override
    
       public void init(FilterConfig filterConfig) throws ServletException {
    
       }
    
     
       @Override
    
       public void destroy() {
    
       }
    
     
    }

     

    2.解决全局的编码

    1)解决中文登录名写入cookie的问题

    解决方法:写入cookie的时候用utf-8编码,读出的时候再解码

    //对中文张三进行编码
    
    String username_code = URLEncoder.encode(username, "UTF-8");// %AE4%kfj
    
    //恢复中文用户名
    
    cookie_username = URLDecoder.decode(cookie_username, "UTF-8");

     

     

    2)解决全局的编码问题(核心代码)

    public class EncodingFilter implements Filter{
    
     
    
      
    
       @Override
    
       public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
    
             throws IOException, ServletException {
    
         
    
          //request.setCharacterEncoding("UTF-8");
    
         
    
          //在传递request之前对request的getParameter方法进行增强
    
          /*
    
           * 装饰者模式(包装)
    
           *
    
           * 1、增强类与被增强的类要实现统一接口
    
           * 2、在增强类中传入被增强的类
    
           * 3、需要增强的方法重写 不需要增强的方法调用被增强对象的
    
           *
    
           */
    
         
    
          //被增强的对象
    
          HttpServletRequest req = (HttpServletRequest) request;
    
          //增强对象
    
          EnhanceRequest enhanceRequest = new EnhanceRequest(req);
    
          chain.doFilter(enhanceRequest, response);
    
       }
    
     
    
       @Override
    
       public void destroy() {
    
       }
    
      
       @Override
    
       public void init(FilterConfig filterConfig) throws ServletException {
    
       }
    
    
    }
    
     
    
    class EnhanceRequest extends HttpServletRequestWrapper{
    
      
    
       private HttpServletRequest request;
    
     
    
       public EnhanceRequest(HttpServletRequest request) {
    
          super(request);
    
          this.request = request;
    
       }
    
      
    
       //对getParaameter增强
    
       //注意request中还有类似getParaameter的方法,
    
       //这些方法获取还是乱码,所以都建议进行重写
    
       @Override
    
       public String getParameter(String name) {
    
          String parameter = request.getParameter(name);//乱码
    
          try {
    
             parameter = new String(parameter.getBytes("iso8859-1"),"UTF-8");
    
          } catch (UnsupportedEncodingException e) {
    
             e.printStackTrace();
    
          }
    
          return parameter;
    
       }
    
    }

     

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-2 16:58 , Processed in 0.058600 second(s), 27 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表