CXF拦截器(Interceptor)LoggingInInterceptor

Interceptor是CXF架构中一个重要的功能。你可以在不对核心模块进行修改的情况下,动态添加很多功能(你可以想象Struts2拦截器的优点)。这对于CXF这个以处理消息为中心的服务框架来说是非常有用的,CXF通过在Interceptor中对消息进行特殊处理,实现了很多重要功能模块,例如:日志记录,Soap消息处理,消息的压缩处理。

CXF已经实现了很多种拦截器,很多已经在发布、访问Web 服务时已经默认添加到拦截器链。一般情况下, 我们自己的拦截器只要继承AbstractPhaseInterceptor<T extends org.apache.cxf.message.Message>类即可,这个类可以指定继承它的拦截器在什么阶段被启用,阶段属性可以通过org.apache.cxf.phase.Phase 中的常量指定值。

下面简单通过实例来表述一下CXF拦截器功能;

一、拦截器实现

1、拦截器的代码实现

Java代码  

  1. public class HelloInInterceptor extends AbstractPhaseInterceptor<Message> {
  2. public HelloInInterceptor(String phase) {
  3. super(phase);
  4. }
  5. public HelloInInterceptor() {
  6. super(Phase.RECEIVE);
  7. }
  8. /** <功能详细描述>
  9. * 创 建 人:  XX
  10. * 创建时间:  2012-9-28 下午02:34:07
  11. * @param arg0
  12. * @throws Fault
  13. * @see [类、类#方法、类#成员]
  14. */
  15. public void handleMessage(Message message) throws Fault {
  16. System.out.println("*********In****Helloworld******");
  17. }
  18. }

注意:你要注意CXF 中的拦截器编写时不要只针对服务端或者客户端,应该是两者均可使用,另外名字要见名知意。例如:使用In、Out 标注这是一个输入时起作用还是输出时起作用的拦截器。上面的HelloInInterceptor由于在构造方法中指定在接收消息阶段有效,所以即使你把它注册到OutInterceptor 的集合中也无效。

2、在spring对自定义拦截器的配置

Java代码  

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xmlns:jaxws="http://cxf.apache.org/jaxws"
  5. xmlns:jaxrs="http://cxf.apache.org/jaxrs"
  6. xsi:schemaLocation=" http://www.springframework.org/schema/beans
  7. http://www.springframework.org/schema/beans/spring-beans.xsd
  8. http://cxf.apache.org/jaxws http://cxf.apache.org/schemas/jaxws.xsd
  9. http://cxf.apache.org/jaxrs http://cxf.apache.org/schemas/jaxrs.xsd">
  10. <import resource="classpath:META-INF/cxf/cxf.xml" />
  11. <import resource="classpath:META-INF/cxf/cxf-extension-soap.xml" />
  12. <import resource="classpath:META-INF/cxf/cxf-servlet.xml" />
  13. <bean id="inMessageInterceptor" class="org.apache.cxf.interceptor.LoggingInInterceptor" />
  14. <bean id="outMessageInterceptor" class="org.apache.cxf.interceptor.LoggingOutInterceptor"/>
  15. <bean id="helloInInterceptor" class="com.exp.service.outer.interceptor.HelloInInterceptor"/>
  16. <!--id:名称(随意配),implementor:指定接口具体实现类,address:随意配-->
  17. <jaxws:endpoint id="helloWorld"  implementor="#HelloWorldImpl" address="/HelloWorld"  >
  18. <!-- 输入日志拦截器 -->
  19. <jaxws:inInterceptors>
  20. <ref bean="inMessageInterceptor"/>
  21. <ref bean="helloInInterceptor"/>
  22. </jaxws:inInterceptors>
  23. <!-- 输出日志拦截器 -->
  24. <jaxws:outInterceptors>
  25. <ref bean="outMessageInterceptor"/>
  26. </jaxws:outInterceptors>
  27. <jaxws:properties>
  28. <entry key="mtom_enabled" value="true"></entry>
  29. </jaxws:properties>
  30. <!--
  31. <jaxws:features>
  32. <bean class="com.exp.service.outer.interceptor.HelloWorldFeature"></bean>
  33. </jaxws:features> -->
  34. </jaxws:endpoint>
  35. <jaxrs:server id="rest_HelloWorld" address="/">
  36. <jaxrs:inInterceptors>
  37. <ref bean="inMessageInterceptor"/>
  38. </jaxrs:inInterceptors>
  39. <jaxrs:outInterceptors>
  40. <ref bean="outMessageInterceptor"/>
  41. </jaxrs:outInterceptors>
  42. <jaxrs:serviceBeans>
  43. <ref bean="rest_HelloWorldImpl" />
  44. </jaxrs:serviceBeans>
  45. <jaxrs:extensionMappings>
  46. <entry key="json" value="application/json" />
  47. <entry key="xml" value="application/xml" />
  48. </jaxrs:extensionMappings>
  49. <jaxrs:languageMappings>
  50. <entry key="en" value="en-gb" />
  51. </jaxrs:languageMappings>
  52. </jaxrs:server>
  53. <!-- WebService 客户端 spring 配置文件cxf与Spring集成,cxf里提供了一个工厂类org.apache.cxf.jaxws.JaxWsProxyFactoryBean,
  54. 可以方便实现的调用WebService。serviceClass属性是接口类,address是webService的路径在其他bean里如果要调用webservice,
  55. 只要将client这个bean注入到需要使用的bean里。-->
  56. <bean id="client" class="com.exp.service.outer.HelloWorld" factory-bean="clientFactory" factory-method="create" />
  57. <bean id="clientFactory" class="org.apache.cxf.jaxws.JaxWsProxyFactoryBean">
  58. <property name="serviceClass" value="com.exp.service.outer.HelloWorld" />
  59. <property name="address" value="http://localhost:8080/demo/webservice/HelloWorld" />
  60. </bean>
  61. </beans>

注意:修改的代码如下:

Java代码  

  1. <jaxws:endpoint id="helloWorld"  implementor="#HelloWorldImpl" address="/HelloWorld"  >
  2. <!-- 输入日志拦截器 -->
  3. <jaxws:inInterceptors>
  4. <ref bean="inMessageInterceptor"/>
  5. <ref bean="helloInInterceptor"/>
  6. </jaxws:inInterceptors>
  7. <!-- 输出日志拦截器 -->
  8. <jaxws:outInterceptors>
  9. <ref bean="outMessageInterceptor"/>
  10. </jaxws:outInterceptors>
  11. <jaxws:properties>
  12. <entry key="mtom_enabled" value="true"></entry>
  13. </jaxws:properties>
  14. <!--
  15. <jaxws:features>
  16. <bean class="com.exp.service.outer.interceptor.HelloWorldFeature"></bean>
  17. </jaxws:features> -->
  18. </jaxws:endpoint>

二、多拦截器的捆绑

由于不光CXF内置有拦截器,而且还可以自定义拦截器。这样WebServcie的SEI可能配置多个、一大堆拦截器,这样很不方便。在Struts2中可以自定义拦截器,他还提供了自定义拦截器堆栈的功能,将多个拦截器捆绑在一起使用。这样不必要一个一个的去注册拦截器。在CXF中也有类似功能,可以将拦截器捆绑在一起,你就可以将它注册到你要使用的地方,而不必一个一个拦截器的注册使用。

实现拦截器的捆绑过程非常的简单,继承AbstractFeature 类来实现一个新的特征, 只需要覆盖initializeProvider 方法即可。其实Feature 就是将一组拦截器放在其中,然后一并注册使用。

具体实现如下:

1、

Java代码  

  1. public class HelloWorldFeature extends AbstractFeature {
  2. @Override
  3. protected void initializeProvider(InterceptorProvider provider, Bus bus) {
  4. provider.getInInterceptors().add(new LoggingInInterceptor());
  5. provider.getInInterceptors().add(new HelloInInterceptor());
  6. provider.getOutInterceptors().add(new LoggingOutInterceptor());
  7. }
  8. }

注意:能够看到通过HelloWorldFeature.Java捆绑了三个拦截器。

2、在Spring对捆绑拦截器的配置

Java代码  

  1. <jaxws:endpoint id="helloWorld" implementor="#HelloWorldImpl" address="/HelloWorld" >
  2. <jaxws:features>
  3. <bean class="com.exp.service.outer.interceptor.HelloWorldFeature"></bean>
  4. lt;/jaxws:features>
  5. <jaxws:properties>
  6. <entry key="mtom_enabled" value="true"></entry>
  7. </jaxws:properties>
  8. t;/jaxws:endpoint>

看到这里省掉了很多拦截器的配置代码,只需要一个 <jaxws:features>就搞定

时间: 2024-11-02 19:19:02

CXF拦截器(Interceptor)LoggingInInterceptor的相关文章

CXF拦截器介绍及自定义拦截器实现

CXF拦截器是功能的主要实现单元,也是主要的扩展点,可以在不对核心模块进行修改的情况下,动态添加功能.当服务被调用时,会经过多个拦截器链(Interceptor Chain)处理,拦截器链在服务输入(IN)或输出(OUT)阶段实现附加功能,拦截器可以在客户端加入,也可以在服务端加入. 拦截器链的阶段: 拦截器链有多个阶段,每个阶段都有多个拦截器.拦截器在拦截器链的哪个阶段起作用,可以在拦截器的构造函数中声明. 输入拦截器链有如下几个阶段,这些阶段按照在拦截器链中的先后顺序排列. 阶段名称 阶段功

CXF 入门:创建一个基于SOAPHeader的安全验证(CXF拦截器使用)

下面具体的webservice实现类直接用的是上面的,这里不再说明 CXF拦截器使用,创建一个使用SOAPHeader的安全验证   xml格式: <soap:Header> <auth:authentication xmlns:auth="http://gd.chinamobile.com//authentication"> <auth:systemID>1</auth:systemID> <auth:userID>test

Flume-NG源码阅读之SourceRunner,及选择器selector和拦截器interceptor的执行

在AbstractConfigurationProvider类中loadSources方法会将所有的source进行封装成SourceRunner放到了Map<String, SourceRunner> sourceRunnerMap之中.相关代码如下: 1 Map<String, String> selectorConfig = context.getSubProperties( 2 BasicConfigurationConstants.CONFIG_SOURCE_CHANNE

Kafka producer拦截器(interceptor)

Producer拦截器(interceptor)是个相当新的功能,它和consumer端interceptor是在Kafka 0.10版本被引入的,主要用于实现clients端的定制化控制逻辑. 对于producer而言,interceptor使得用户在消息发送前以及producer回调逻辑前有机会对消息做一些定制化需求,比如修改消息等.同时,producer允许用户指定多个interceptor按序作用于同一条消息从而形成一个拦截链(interceptor chain).Intercetpor

【WebService】CXF拦截器的设置以及自定义CXF拦截器

WebService系列文章: [WebService]带你走进webservice的世界 [WebService]自定义WebService服务及其调用 [WebService]wsdl配置详解以及使用注解修改wsdl配置 [WebService]CXF处理javaBean等复合类型以及Map等复杂类型的数据 CXF的拦截器和以前学过的servlet的拦截器类似的,都是在开始或结束切入一段代码,执行一些逻辑之类的.我们可以在调用ws服务前设置拦截器,也可以在调用ws服务后设置拦截器,当然了,拦

详述 Spring MVC 框架中拦截器 Interceptor 的使用方法

1 前言 昨天新接了一个需要,"拦截 XXX,然后 OOO",好吧,说白了就是要用拦截器干点事(实现一个具体的功能).之前,也在网络上搜了很多关于Interceptor的文章,但感觉内容都大同小异,而且知识点零零散散,不太方便阅读.因此,正好借此机会,整理一篇关于拦截器的文章,在此分享给大家,以供大家参考阅读. 2 拦截器 2.1 概念 Java 里的拦截器是动态拦截 action 调用的对象.它提供了一种机制可以使开发者可以定义在一个 action 执行的前后执行的代码,也可以在一个

struts2拦截器interceptor的三种配置方法

struts2拦截器interceptor的三种配置方法方法1. 普通配置法 <struts>     <package name="struts2" extends="struts-default">         <interceptors>             <interceptor name="myInterceptor" class="edu.hust.interceptor.

Struts拦截器Interceptor

Struts2 拦截器 [Interceptor] 拦截器的工作原理如上图,每一个Action请求都包装在一系列的拦截器的内部.拦截器可以在Action执行直线做相似的操作也可以在Action执行直后做回收操作. 每一个Action既可以将操作转交给下面的拦截器,Action也可以直接退出操作返回客户既定的画面. 如何自定义一个拦截器? 自定义一个拦截器需要三步: 1 自定义一个实现Interceptor接口(或者继承自AbstractInterceptor)的类. 2 在strutx.xml中

Flume 拦截器(interceptor)详解

flume 拦截器(interceptor)1.flume拦截器介绍拦截器是简单的插件式组件,设置在source和channel之间.source接收到的事件event,在写入channel之前,拦截器都可以进行转换或者删除这些事件.每个拦截器只处理同一个source接收到的事件.可以自定义拦截器.2.flume内置的拦截器 2.1 时间戳拦截器flume中一个最经常使用的拦截器 ,该拦截器的作用是将时间戳插入到flume的事件报头中.如果不使用任何拦截器,flume接受到的只有message.