Spring接口访问时长统计

目前在线上的应用需要统计一下接口访问的时长,在不变动已有的业务代码的情况下,选择了用Filter来完成这个功能。代码实现如下:

  1. 首先创建一个类,实现Filter接口,将创建好的filter注册到web容器中有两种方法
//1. 一个是用注解的方式.
@WebFilter(filterName = "ApiAccessFilter", urlPatterns = "/*")
//2. 另一个是在配置文件中声明

	<!-- 接口统计时长过滤器 -->
		<filter>
			<filter-name>apiAccessFilter</filter-name>
			<filter-class>com.bda.zjtag.app.filter.ApiAccessFilter</filter-class>
		</filter>
		<filter-mapping>
			<filter-name>apiAccessFilter</filter-name>
			<url-pattern>/*</url-pattern>
		</filter-mapping>

  1. 在doFilter中实现统计接口时长的逻辑
 @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse,
                         FilterChain filterChain) throws IOException, ServletException {

        HttpServletRequest request = (HttpServletRequest) servletRequest;

        long start = System.currentTimeMillis();

        log.info("[Api Access] start. , uri: {}, method: {}, client: {}",
                request.getRequestURI(), request.getMethod());
        filterChain.doFilter(servletRequest, servletResponse);
        log.info("[Api Access]   end. duration: {}ms",
                System.currentTimeMillis() - start);

    }

启动之后,访问接口就会被统计了

2019-10-22 10:03:51.956 [http-nio-8080-exec-1] INFO  c.b.zjtag.app.filter.ApiAccessFilter.doFilter - [Api Access] start. , uri: /, method: GET, client: {}
2019-10-22 10:03:51.997 [http-nio-8080-exec-1] INFO  c.b.zjtag.app.filter.ApiAccessFilter.doFilter - [Api Access]   end. duration: 41ms
2019-10-22 10:03:52.010 [http-nio-8080-exec-1] INFO  c.b.zjtag.app.filter.ApiAccessFilter.doFilter - [Api Access] start. , uri: /, method: GET, client: {}
2019-10-22 10:03:52.015 [http-nio-8080-exec-1] INFO  c.b.zjtag.app.filter.ApiAccessFilter.doFilter - [Api Access]   end. duration: 5ms
2019-10-22 10:03:52.432 [http-nio-8080-exec-5] INFO  c.b.zjtag.app.filter.ApiAccessFilter.doFilter - [Api Access] start. , uri: /, method: GET, client: {}
2019-10-22 10:03:52.447 [http-nio-8080-exec-5] INFO  c.b.zjtag.app.filter.ApiAccessFilter.doFilter - [Api Access]   end. duration: 15ms
2019-10-22 10:04:24.343 [http-nio-8080-exec-6] INFO  c.b.zjtag.app.filter.ApiAccessFilter.doFilter - [Api Access] start. , uri: /, method: GET, client: {}
2019-10-22 10:04:24.347 [http-nio-8080-exec-6] INFO  c.b.zjtag.app.filter.ApiAccessFilter.doFilter - [Api Access]   end. duration: 4ms

完整代码

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;


/**
 * @author lxa
 * @date 2019/10/22 9:40
 */
@WebFilter(filterName = "ApiAccessFilter", urlPatterns = "/*")
public class ApiAccessFilter implements Filter {

    private final Logger log = LoggerFactory.getLogger(this.getClass());

    @Override
    public void init(FilterConfig filterConfig) {

    }

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse,
                         FilterChain filterChain) throws IOException, ServletException {

        HttpServletRequest request = (HttpServletRequest) servletRequest;

        long start = System.currentTimeMillis();

        log.info("[Api Access] start. , uri: {}, method: {}, client: {}",
                request.getRequestURI(), request.getMethod());
        filterChain.doFilter(servletRequest, servletResponse);
        log.info("[Api Access]   end. duration: {}ms",
                System.currentTimeMillis() - start);

    }

    @Override
    public void destroy() {

    }


}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值