filter过滤器

1.什么是过滤器

          过滤器实际上就是对web资源进⾏拦截,做⼀些处理后再交给下⼀个过滤器或servlet处理,通常都 是⽤来拦截request进⾏处理的,也可以对返回的response进⾏拦截处理。

 2.过滤器的语法格式

    2.1.创建⼀个类实现Filter接⼝

public class Encoding  implements Filter{}

  2.2.重写接⼝中的⽅法

public void destroy() { //销毁的⽅法}
public void doFilter(ServletRequest req, ServletResponse resp, FilterChain
chain) throws ServletException, IOException {
 //过滤⽅法 主要是对request和response进⾏⼀些处理,然后交给下⼀个过滤器或Servlet处理
 filterChainn.doFilter(req, resp);
 }
 public void init(FilterConfig config) throws ServletException {
 /*初始化⽅法 接收⼀个FilterConfig类型的参数 该参数是对Filter的⼀些配置*/
}

  2.3.在web.xml⽂件中配置

<filter>
 <filter-name>过滤器名称</filter-name>
 <filter-class>过滤器所在的路径</filter-class>
</filter>
<filter-mapping>
 <filter-name>过滤器名称</filter-name>
 <url-pattern>需要过滤的资源</url-pattern>
</filter-mapping>

3.使⽤场景

案列(初始化编码)

3.1创建Encoding类实现Filter
public class Encoding implements Filter {
    private String encoding;
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
         //初始编码从web.xml中获得值,设置初始值
         this.encoding = filterConfig.getInitParameter("encoding");
    }

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        HttpServletRequest request = (HttpServletRequest) servletRequest;
        HttpServletResponse response = (HttpServletResponse) servletResponse;
        request.setCharacterEncoding(this.encoding);
        //将请求通过传递到下一个过滤器或Servlet
        filterChain.doFilter(request,response);
    }

    @Override
    public void destroy() {

    }
}
3.2配置web.xml中的初始值
 <filter>
        <filter-name>/Encoding</filter-name>
        <filter-class>web.Encoding</filter-class>
        <init-param>
            <param-name>encoding</param-name>
            <param-value>UTF-8</param-value>
        </init-param>
 </filter>
<filter-mapping>
        <filter-name>/Encoding</filter-name>
        <!--过滤的servlet-->
        <url-pattern>*.do</url-pattern>
</filter-mapping>

其他场景

  • 身份验证:通过Filter过滤器来实现身份验证功能,只有通过验证的用户才能访问指定的页面或资源。
  • 日志记录:通过Filter过滤器来记录用户的请求和响应信息,以便进行统计和分析。
  • 安全过滤:通过Filter过滤器来过滤恶意请求,以提高Web应用程序的安全性。

总结

总之,Filter过滤器是Java Web应用程序中非常实用的组件,可以帮助我们更好地管理和处理请求和响应,提高Web应用程序的可靠性、安全性和可扩展性

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值