使用CXF为webservice添加拦截器

拦截器分为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);

}

}

时间: 2024-10-16 13:00:48

使用CXF为webservice添加拦截器的相关文章

webservice之拦截器

记录一次webservice添加拦截器,来达到修改xml报文的目的 import org.apache.cxf.endpoint.Client; import org.apache.cxf.frontend.ClientProxy; private Soap createSoap() { service = new Service(); soap = service.getServiceSoap(); //拦截器改造报文头 client = ClientProxy.getClient(soap)

WebService学习笔记-CXF添加拦截器

Webservice拦截器:在webservice请求过程中,动态操作请求和响应的数据 分类 按照所处的位置分:服务器端拦截器  客户端拦截器 按照消息的方向分:入拦截器  出拦截器 按照定义者分:系统拦截器 自定义拦截器 在服务器端添加拦截器 package com.demo; //注意引入的类一定要正确 import javax.xml.ws.Endpoint; import org.apache.cxf.interceptor.LoggingInInterceptor; import or

Webservice:CXF添加拦截器实现权限控制

上一遍简单介绍了webservice和写了简单的cxf入门小程序 地址:http://blog.csdn.net/cjaver/article/details/38777057 接下来介绍一个比较实用的拦截器,可以进行权限控制等. 首先对于 一个 webservice来说 服务器端 : 有输入有输出(soap) 客户端: 同上 所以对于添加拦截器来说,也是有 In 拦截器 跟 Out拦截器 这里简单写一个服务器端的 In拦截器(控制发送过来的消息必须有 用户名,密码,所以添加的In拦截器) pu

cxf添加拦截器应用

项目中有时候也会做一些类似于权限验证的东西,拦截器也是一种实现方式.拦截器主要作用是做一些权限过滤,编码处理等. webService接口也可以上拦截器,我们也可以给webservice请求加权限判断功能: webservice分服务端和客户端,服务端和客户端都是可以加拦截器的,无论是服务端还是客户端,都分进,出(In,Out)拦截器: 可以使用cxf内置拦截器,也可以自定义拦截器,无论是自定义的拦截器,还是CXF自带的拦截器,都必须实现Interceptor接口. 下面分别从这两个方面来讲解:

WebService框架CXF实战一自定义拦截器(五)

CXF已经内置了一些拦截器,这些拦截器大部分默认添加到拦截器链中,有些拦截器也可以手动添加,如手动添加CXF提供的日志拦截器.也可以自定义拦截器,CXF中实现自定义拦截器很简单,只要继承AbstractPhaseInterceptor或者AbstractPhaseInterceptor的子类(如AbstractSoapInterceptor)即可. 自定义权限认证拦截器 权限认证拦截器处理SOAPHeader中的认证信息,客户端在发起请求时在SOAPHeader中添加认证信息,服务端在接收到请求

spring boot 添加拦截器

构建一个spring boot项目. 添加拦截器需要添加一个configuration @Configuration @ComponentScan(basePackageClasses = Application.class, useDefaultFilters = true) public class ServletContextConfig extends WebMvcConfigurationSupport { 为了方便扫描位置,我们可以写一个接口或者入口类Application放置于最外

springmvc添加拦截器

springmvc.xml配置如下: 除了 sysFile 下的所有接口,以及user下的loginUser接口,其他的所有接口都会经过拦截器UserInterceptor处理 <mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/**" /> <mvc:exclude-mapping path="/sysFile/**" /> <mvc:exclude

在MVC中添加拦截器实现登录后的权限验证

1.新建一个类 (以下实现了打印日志功能) using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Mvc; namespace MvcReporistory.Controllers { public class LoggerFilter : FilterAttribute, IActionFilter { void IActionFilter.On

web api添加拦截器

实现思路 1.标识控制器有拦截特性: 2.控制器拦截处理: 代码实现 1.标识控制器有拦截特性,代码: [MyFilter] public string PostFindUser([FromBody]Userinfo user) { return string.Format("{0}是好人~", user.Name); } 2.控制器拦截处理,代码: public class MyFilter : ActionFilterAttribute { public override void