我正在使用Spring Boot编写Web Rest Web服务.
我想记录我的webservice处理请求所花费的时间.
另外我想记录调用的头文件,方法和URI.
几个月前我使用ContainerRequestFilter和ContainerResponseFilter filter()方法在我的球衣网络服务中做了类似的工作.
另外,AOP更好还是过滤?
最佳答案
你试过像这样的基本过滤器吗?
import java.io.IOException;
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
@Component
@WebFilter("/*")
public class StatsFilter implements Filter {
private static final Logger LOGGER = LoggerFactory.getLogger(StatsFilter.class);
@Override
public void init(FilterConfig filterConfig) throws servletexception {
// empty
}
@Override
public void doFilter(ServletRequest req,ServletResponse resp,FilterChain chain) throws IOException,servletexception {
long time = System.currentTimeMillis();
try {
chain.doFilter(req,resp);
} finally {
time = System.currentTimeMillis() - time;
LOGGER.trace("{}: {} ms ",((HttpServletRequest) req).getRequestURI(),time);
}
}
@Override
public void destroy() {
// empty
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。