Filter拦截用户请求
下面这个Filter负责拦截所有用户的用户请求:
1.创建Filter必须实现javax.servlet.Fileter接口。
2.
1 // FilterConfig可用于访问Filter的配置信息 2 private FilterConfig config; 3 // 实现初始化方法 4 public void init(FilterConfig config) 5 { 6 this.config = config; 7 } 8 // 实现销毁方法 9 public void destroy() 10 { 11 this.config = null; 12 }
destory方法用于在Filter销毁前,完成某些资源的回收。
3.
1 // 获取ServletContext对象,用于记录日志 2 ServletContext context = this.config.getServletContext(); 3 long before = System.currentTimeMillis(); 4 System.out.println("开始过滤..."); 5 // 将请求转换成HttpServletRequest请求 6 HttpServletRequest hrequest = (HttpServletRequest)request; 7 // 输出提示信息 8 System.out.println("Filter已经截获到用户的请求的地址: " + 9 hrequest.getServletPath());
上面这一段代码是对用户请求进行预处理。
(1)currentTimeMillis方法的作用是返回当前的计算机时间,时间的表达格式为当前计算机时间和GMT时间(格林威治时间)1970年1月1号0时0分0秒所差的毫秒数。而且可以用这个值来构造一个Date对象。
4.
// Filter只是链式处理,请求依然放行到目的地址 chain.doFilter(request, response);
实现该方法前对用户请求进行预处理,实现后对服务器响应进行后处理。
5.
long after = System.currentTimeMillis(); // 输出提示信息 System.out.println("过滤结束"); // 输出提示信息 System.out.println("请求被定位到" + hrequest.getRequestURI() + " 所花的时间为: " + (after - before));
对服务器响应执行后处理。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律