拦截器分为Service端和Client端
1、Service端:
通过将org.apache.cxf.jaxws.EndpointImpl类的方法即可实现
部分代码:
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());
//此
拦截器是自定义的
拦截器。
ep.getOutInterceptors()
ep.getInInterceptors()
ep.getInInterceptors()
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());
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"));
client.getOutInterceptors().add( new AddHeaderInterceptor( "crazyit"
3、自定义的拦截器
部分代码
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);
}
}
}
{
}