文档章节

使用CXF为Web Service添加拦截器,自定义拦截器

车开源
 车开源
发布于 2016/04/14 16:56
字数 474
阅读 78
收藏 3
拦截器分为Service端Client端

    拦截器是在发送soap消息包的某一个时机拦截soap消息包,对soap消息包的数据进行分析或处理。分为CXF自带的拦截器自定义的拦截器

1、Service端:

通过将org.apache.cxf.jaxws.EndpointImpl类的方法即可实现

  发布Web Service 方法可以通过Endpoint.publish()方法,此方法返为EndpointImpl,所以为Service端添加拦截器很简单。

UserService us = new UserServiceImpl();
String address = "http://192.168.10.254:9999/crazyit";
EndpointImpl ep = (EndpointImpl)Endpoint.publish(address , us);

//下面方法就可以添加拦截器(CXF提供的拦截器)
//cxf-2.2.10.jar  org.apache.cxf.interceptor.* (CXF提供的拦截器)
ep.getOutInterceptors()
    .add(new LoggingOutInterceptor());
ep.getInInterceptors()
    .add(new LoggingInInterceptor());
ep.getInInterceptors()
    .add(new AuthIntercetpr()); //此拦截器是自定义的拦截器。



2、Client端
客户端可以通过对org.apache.cxf.frontend.ClientProxy中的getClient()方法获取
org.apache.cxf.endpoint.Client对象,该对象可以为客户端添拦截器。

//为客户端添加拦截器
org.apache.cxf.endpoint.Client client = ClientProxy.getClient(us);
client.getInInterceptors().add(new LoggingInInterceptor());
client.getOutInterceptors().add(new LoggingOutInterceptor());
//自定义拦截器
client.getOutInterceptors().add(new AddHeaderInterceptor("crazyit" , "crazyit.org2"));



3、自定义的拦截器

  自定义拦截器需要继承org.apache.cxf.phase.AbstractPhaseInterceptor抽象类,并实现其handleMessage方法,与重写自定义的构造器(由于AbstractPhaseInterceptor没有无参构造器,所以要在自定义构拦截器的造器中调用supper(带参数))。

public class AuthIntercetpr
    extends AbstractPhaseInterceptor<SoapMessage>
{
    public AuthIntercetpr()
    {
        //子类总会调用父类的构造器,
        //默认是调用无参数的构造器。

        //指定该拦截器在哪个阶段被激发
        super(Phase.PRE_INVOKE);
    }

    //处理消息
    public void handleMessage(SoapMessage message)
    {
        System.out.println("==================" + message);

        //获取SOAP消息的全部头
        List<Header> headers = message.getHeaders();

        if(headers.size() < 1)
        {
            throw new Fault(new SOAPException("SOAP消息头格式不对哦!"));
        }        

        for(Header header : headers)
        {
            SoapHeader soapHeader = (SoapHeader)header;
            //取出SOAP的Header元素
            Element element = (Element)soapHeader.getObject();
            checkSOAPHeader(element);
        }    
    }
}



本文转载自:http://blog.csdn.net/a9529lty/article/details/8437599

共有 人打赏支持
车开源
粉丝 12
博文 33
码字总数 8419
作品 0
佛山
后端工程师
CXF 中自定义SOAPHeader

拦截器(Interceptor)简单说明 Interceptor是CXF架构中一个很有特色的模式。你可以在不对核心模块进行修改的情况下,动态添加很多功能。这对于CXF这个以处理消息为中心的服务框架来说是非常有...

核桃白果
2013/08/08
0
3
webservice与web 做整合

由于cxf的web项目已经集成了Spring所以,cxf的服务类都是在spring的配置文件中完成的。以下是步骤: 第一步:建立一个web项目。 第二步:准备所有jar包。将cxf_homelib项目下的所有jar包全部...

chenruibing
2015/06/01
0
0
Web Service的CXF实现(Spring整合方式)

新建Java Web项目,采用maven管理jar包,本文章只是提供核心代码文件如下: (1)maven的pom.xml (2)cxf-base.xml (3)cxf-bz-client.xml 客户端配置 (4)cxf-bz-server.xml服务端配置 (5)WSOrd...

蚂蚁也疯狂
2014/01/27
0
11
CXF 入门:创建一个基于SOAPHeader的安全验证(CXF拦截器使用)

下面具体的webservice实现类直接用的是上面的,这里不再说明 CXF拦截器使用,创建一个使用SOAPHeader的安全验证 xml格式: soap:Header </soap:Header> 一,首先在服务端创建一个拦截器(被调用...

闪电
2015/05/15
0
0
使用CXF Interceptor特性

在Web Service中,客户端和服务端通过交换信息来互相通信。信息在客户端组装,在服务端解组。在Web Service术语中,组装表示将JAVA对象转换为XML文件,这些XML文档将被传输到网络中;反而言之...

核桃白果
2013/08/06
0
0

没有更多内容

加载失败,请刷新页面

加载更多

OSX | SafariBookmarksSyncAgent意外退出解决方法

1. 启动系统, 按住⌘-R不松手2. 在实用工具(Utilities)下打开终端,输入csrutil disable, 然后回车; 你就看到提示系统完整性保护(SIP: System Integrity Protection)已禁用3. 输入reboot回车...

云迹
今天
4
0
面向对象类之间的关系

面向对象类之间的关系:is-a、has-a、use-a is-a关系也叫继承或泛化,比如大雁和鸟类之间的关系就是继承。 has-a关系称为关联关系,例如企鹅在气候寒冷的地方生活,“企鹅”和“气候”就是关...

gackey
今天
4
0
读书(附电子书)|小狗钱钱之白色的拉布拉多

关注公众号,在公众号中回复“小狗钱钱”可免费获得电子书。 一、背景 之前写了一篇文章 《小狗钱钱》 理财小白应该读的一本书,那时候我才看那本书,现在看了一大半了,发现这本书确实不错,...

tiankonguse
今天
4
0
Permissions 0777 for ‘***’ are too open

异常显示: @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ @ WARNING: UNPROTECTED PRIVATE KEY FILE! @ @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ ......

李玉长
今天
5
0
区块链10年了,还未落地,它失败了吗?

导读 几乎每个人,甚至是对通证持怀疑态度的人,都对区块链的技术有积极的看法,因为它有可能改变世界。然而,区块链技术问世已经10年了,我们仍然没有真正的用上区块链技术。 几乎每个人,甚...

问题终结者
今天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部