gpt4 book ai didi

java - Jersey 有没有办法从 javax.ws.rs.Client 获取请求信息?

转载 作者:行者123 更新时间:2023-12-02 12:30:10 25 4
gpt4 key购买 nike

我正在尝试为基于 jersey 构建的项目制定日志记录标准,并且我想提供一种简单的方法来记录请求信息和响应,以防发生异常。下面的代码说明了我的想法:

    Client client = null;
Response response = null;
try {
client = ClientBuilder.newClient();
response = client.target("<URL>")
.request(MediaType.APPLICATION_JSON)
.post(entity);
} catch( Exception ex) {
//Send information for exception mapping to a JSON log
throw new ServiceException( client,response );
}

问题是如何在我的 ServiceException 类中获取以下内容:

    String url = client.getUri().toString(); //only one I could get using WebTarget
MultivaluedMap<String, String> headers = client.getHeaders();
String body = client.getEntity();
MultivaluedMap<String, String> queryParams = client.getQueryParams();
String method = client.getMethod();

我尝试访问 WebTarget 但没有成功。

提前致谢!

最佳答案

Jersey 有 logging support对于客户端和服务器端。该文档展示了如何向 Client 注册它。它也可以通过 WebtTarget 注册。

如果您对结果不满意,并且想要实现自己的结果,我会按照 Jersey 的方式实现它:结合使用 WriterInterceptor 来记录请求实体流1Client(Request|Response)Filter2来获取请求和响应的其他部分(例如 header 和请求行)。

您可以查看 ClientLoggingFilter 的来源和 LoggingInterceptor以获得一些实现想法。

<小时/>

1 - 它需要使用拦截器,而不是只使用过滤器来处理所有内容,因为过滤器只会为您提供预先序列化的对象,该对象可以是任何东西,很难记录。使用输入流进行通用日志记录更容易

2 - 请参阅 Filters and Interceptors

关于java - Jersey 有没有办法从 javax.ws.rs.Client 获取请求信息?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45310074/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com