- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用 CXF 和 JAX-RS 构建 RESTFul API 来为我的 Web 应用程序提供数据。我想知道是否可以记录请求 X 发送到我的 API、进行处理然后作为响应返回所需的时间。
我已经将自己的 CXF 记录器定义为 JAX-RS 功能,因为 <cxf:logging />
有点太多了。话虽如此,我知道有一个用于请求记录器的记录器,并且有一个响应记录器。我的网络应用程序实际上记录了所有请求/响应,如下所示:
11-21 10:37:01,052 INFO [-8080-exec-7] +- CXF Request -- ID : [24], Address : [http://my.api.com], HTTP Method : [GET] @org.apache.cxf.interceptor.LoggingOutInterceptor
11-21 10:37:01,089 INFO [-8080-exec-7] +- CXF Response -- ID : [24], Response Code : [200] @org.apache.cxf.interceptor.LoggingInInterceptor
有没有办法可以从客户端跟踪时间并记录它?
最佳答案
该线程是一个旧线程,但分享了我在客户端采取的方法。
我们与服务器进行了基于 SOAP 的交换,因此我们的类扩展了 AbstractSoapInterceptor
在handleMessage()中,我们找到消息的方向(入站或出站),并计算处理所需的时间。
public void handleMessage(SoapMessage message) throws Fault {
try {
boolean isOutbound = MessageUtils.isOutbound(message);
if (isOutbound) {
// outgoing
long requestSentTime = System.currentTimeMillis();
LOGGER.trace("Sending request to server at {} milliseconds", requestSentTime);
message.getExchange().put(ApplicationConstants.CXF_REQUEST_TIME, requestSentTime);
} else {
// incoming
long requestSentTime = (long) message.getExchange().get(ApplicationConstants.CXF_REQUEST_TIME);
long requestReceiveTime = System.currentTimeMillis();
LOGGER.trace("Receiving request from server at {} milliseconds", requestReceiveTime);
long executionTime = requestReceiveTime - requestSentTime;
LOGGER.info("Server execution time in milliseconds was {}", executionTime);
}
} catch (Exception e) {
LOGGER.error("handleMessage() threw exception {} ", e);
// Log and do nothing
}
}
<bean id="processingTimeInterceptor" class="ProcessingTimeInterceptor" />
<jaxws:client ...">
<jaxws:inInterceptors>
<ref bean="processingTimeInterceptor" />
</jaxws:inInterceptors>
<jaxws:outInterceptors>
<ref bean="processingTimeInterceptor" />
</jaxws:outInterceptors>
</jaxws:client>
关于CXF 日志响应时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20125276/
我将Eclipse Helios Service Release 2版本用于apache cxf。当我转到windo->首选项-> Web服务-> CXF 2.x首选项,并设置cxf运行时时,版本和类
我是任何开放框架的新手(我是基于 java 的解决方案工程师)并试图构建一个 cxf 项目。 我知道我需要 applicationContext.xml文件和内容之类的
我想为不同的目的注册不同的类,以便在同一阶段调用 (Phase.PRE_INVOKE)。是否可以? 最佳答案 看这里http://cxf.apache.org/docs/interceptors.ht
我想使用 wsdl2java(CXF) 命令生成自定义包。 我的 WSDL 结构是: wsdl:definitions xmlns:wsdl="http://schemas.xmlsoap.org/w
我在通过 JAXRSClientFactoryBean.create 创建的 CXF 中有一个 JAX-RS 客户端。如何设置连接/接收超时? 我想我需要掌握管道,但不知道如何操作。这个项目没有使用
鉴于来自 fuse 源的 apache-servicemix-4.4.1-fuse-00-08 的“cxf-osgi”示例,使用 maven 3.0.3 构建,将其部署到 apache karaf 2
这个问题在这里已经有了答案: How do I fix a NoSuchMethodError? (33 个答案) 关闭 29 天前。 我刚刚尝试通过 Maven 使用 Apache CXF 和 S
我正在尝试使用 Apache CXF 开发一个 API 调用,该调用会随请求一起接收附件。我遵循了 this 教程,这就是我到目前为止所得到的。 @POST @Path("/upload") @Req
'org.apache.cxf.tools.wsdlto.WSDLToJava' 将 wsdl 转换为 java 类。 它是在内部使用 JAXB 吗?为什么这个命令能够生成类似于“xjc”创建的类?有
我已经使用 CXF 和 Spring 开发了一个 Java Web 服务。 由于安全原因,我想隐藏 WSDL,尽管 WS 仍然可用。 有没有办法使用 CXF 做到这一点? 最佳答案 您可以在 web.
我有一个生成的 JAXB 类(来自 XSD)。我能够以 XML 和 JSON 的形式返回,但是一旦我将 text/html 添加到我的 Produces 注释中,我就会得到: "No message
我创建了一个非常简单的基于 cxf 的非 spring Servlet,它加载了一个 javax.ws.rs.Application类型。 这是 web.xml: CXFSe
我正在使用 JBOSS EAP 6.2 来部署 restful web 服务。 restful web 服务使用 apache cxf,它取自 jboss eap。目前它使用 jar cxf-api-
我有一个服务方法定义为: public JaxbList getDeal() { List deals = new ArrayList(); Deal type = new Deal(
我需要将 wadl 转换为 java pojo,为此我已经下载了 apache cxf 3.0.1 版本。但是当我在命令提示符下运行 wadl2java bat 文件时,出现以下异常 D:\softw
这个问题在这里已经有了答案: 9年前关闭。 Possible Duplicate: Which maven2 artifacts are necessary to build a WS with CX
我想将一个简单的 CXF Jax-Ws 服务器部署到 ServiceMix。它只是一个同时具有服务接口(interface)和 impl 类的 OSGI 包。我需要将它部署到不同的 ServiceMi
是否可以在 wso2 ESB 中部署 CXF Web 服务? 目前我已经开始从 WSO2 User Guide 引用 wso2 的文档。我想将现有的 CXF Web 服务部署到 ESB。因此,有关这方
我想了解 cxf-bundle和 cxf-bundle-jaxrs jar 。它们是两个不同的 jar ,还是前者本身包含后者? 谢谢,巴蒂亚 最佳答案 前者包含后者。 但是,您实际上不应该使用其中任
我已经built and deployed a custom web services consumer in Java on Domino using the available CXF frame
我是一名优秀的程序员,十分优秀!