ContainerRequestContext和ContainerResponseContext

本文深入探讨了RESTful服务中过滤器的实现原理,重点介绍了public void filter(ContainerRequestContext requestContext, ContainerResponseContext responseContext)方法如何在请求和响应过程中进行拦截与处理,为开发者提供了一种控制HTTP请求流程的有效手段。

public void filter(ContainerRequestContext requestContext, ContainerResponseContext responseContext)

public class TrafficStatisticsFilter implements ContainerRequestFilter, ContainerResponseFilter { // 全局计数器:请求数、请求总大小、响应总大小(使用原子变量保证线程安全) private static final AtomicLong requestCount = new AtomicLong(0); private static final AtomicLong responseCount = new AtomicLong(0); private static final AtomicLong totalRequestSize = new AtomicLong(0); private static final AtomicLong totalResponseSize = new AtomicLong(0); @Override public void filter(ContainerRequestContext requestContext) throws IOException { // 统计请求:增加计数,测量请求体大小 requestCount.incrementAndGet(); if (requestContext.hasEntity()) { int size = requestContext.getEntityStream().available(); // 获取输入流大小 totalRequestSize.addAndGet(size); } } @Override public void filter(ContainerRequestContext requestContext, ContainerResponseContext responseContext) throws IOException { responseCount.incrementAndGet(); // 统计响应:测量响应体大小 if (responseContext.hasEntity()) { Object entity = responseContext.getEntity(); // 简化示例:实际中需序列化对象或读取输出流计算大小 int size = entity.toString().getBytes().length; // 估算响应体大小 totalResponseSize.addAndGet(size); } } // 提供获取统计数据的静态方法 public static String getTrafficStats() { return String.format("请求数: %d, 响应数: %d, 总请求大小: %d bytes, 总响应大小: %d bytes", requestCount.get(), responseCount.get(), totalRequestSize.get(), totalResponseSize.get()); } } 如何调用 getTrafficStats ?
最新发布
09-29
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值