webservice拦截器 查看消息包(soap)

服务端:

    1.获取EndpointImpl对象

    2.调用EndpointImpl对象中的方法获取In拦截器
    3.调用EndpointImpl对象中的方法获取out拦截器

    4.添加自己的In拦截器与Out拦截器

      LogginInInterceptor:查看收到的消息包

      LoggOutInterceptor:查看发出去的消息包

客户端:

    需要导入cxf的7个jar包:

    1.获取client对象

      Client client=ClientProxy.getClient("ws服务组件代理对象") ---ws服务组件 就是  new 服务接口().getXxxPort();  就是服务端服务接口的实现类

    2.调用client对象中的方法获取In拦截器
    3.调用client对象中的方法获取out拦截器

    4.添加自己的In拦截器与Out拦截器

      LogginInInterceptor:查看收到的消息包

      LoggOutInterceptor:查看发出去的消息包

------------------------添加权限拦截器-----------------------------------

1.在soap包中添加Header元素,携带鉴定权限的数据

<Header>

  <auth>

    <auth_id>账号</auth_id>

    <auth_pwd>密码</auth_pwd>

  </auth>

</Header>

2.客户端------在发送soap包之前修改header头元素需要添加out拦截器

3.服务端------添加in拦截器解析soap包header头元素

4.自定义拦截器--需要继承AbstractPhaseInterceprot;

----------------------------自定义拦截器案例----------------------------

public class HeaderInterceptor extends AbstractPhaseInterceptor<SoapMessage> {
private String authId;
private String pwd;

public HeaderInterceptor(String authId, String pwd) {
/** 在发送soap包之前该拦截器起作用 */
super(Phase.PREPARE_SEND);
this.authId = authId;
this.pwd = pwd;
}

@Override
public void handleMessage(SoapMessage soapMessage) throws Fault {

/**
* <auth>
<auth_id>admin</auth_id>
<auth_pwd>888888</auth_id>
</auth>
*/
// 创建Document
Document doc = DOMUtils.createDocument();
// 创建Element
Element authEle = doc.createElement("auth");
Element idEle = doc.createElement("auth_id");
// 添加文本
idEle.setTextContent(authId);
Element pwdEle = doc.createElement("auth_pwd");
// 添加文本
pwdEle.setTextContent(pwd);

// 追加元素
authEle.appendChild(idEle);
authEle.appendChild(pwdEle);

// 创建Header头
Header header = new Header(new QName("it"), authEle);

// 获取所有的header头, 添加header头
soapMessage.getHeaders().add(header);

}

public String getAuthId() {
return authId;
}

public void setAuthId(String authId) {
this.authId = authId;
}

public String getPwd() {
return pwd;
}

public void setPwd(String pwd) {
this.pwd = pwd;
}

}

时间: 2024-11-12 00:02:37

webservice拦截器 查看消息包(soap)的相关文章

webservice拦截器

CXF的拦截器 理解 为什么设计拦截器? 为了在webservice请求过程中,能动态操作请求和响应数据, CXF设计了拦截器. 拦截器分类: 按所处的位置分:服务器端拦截器,客户端拦截器 按消息的方向分:入拦截器,出拦截器 按定义者分:系统拦截器,自定义拦截器 基于jdk的webservice没有拦截器的功能实现. 接口方法: import javax.jws.WebMethod; import javax.jws.WebService; @WebService public interfac

5.webService拦截器

CXF为什么要设计拦截器? 为了在webservice请求过程中,能动态操作请求和响应数据, CXF设计了拦截器. 拦截器分类 1.按所处的位置分:服务器端拦截器,客户端拦截器 2.按消息的方向分:入拦截器,出拦截器 3.按定义者分:系统拦截器,自定义拦截器 3.1系统拦截器: LoggingInInterceptor(系统日志入拦截器类) LoggingOutInterceptor(系统日志出拦截器类) ***server*** //SEI @WebService public interfa

WebService拦截器的使用

. WebService自定义拦截器只需要继承AbstractPhaseInterceptor即可 . 编写自定义拦截器之后,需要在发布的类和调用类中添加拦截器,分布使用JaxWsServerFactoryBean实例.getInInterceptors().add(自定义拦截器实例);和 JaxWsProxyFactoryBean.getOutInterceptors().add(自定义拦截器实例),进行拦截器的添加. . 一个简单的用户验证的拦截器,具体的代码如下: ------------

7.添加基于Spring的WebService拦截器

客户端拦截器: public class AccountInterceptor extends AbstractPhaseInterceptor<SoapMessage>{ private String name; private String password; public AccountInterceptor(String name,String password) { //Phase值决定了拦截器什么时候拦截到消息 //PRE_PROTOCOL准备请求时拦截 super(Phase.P

springboot 过滤器、拦截器、消息转换器、切片执行顺序 及区别

request 请求 -->1:过滤器 doFilter2:拦截器 preHandle3:消息转换器 readInternal4:AOP before5:Controller6:Response7:AOP after8:消息转换器 writeInternal9:拦截器 postHandle 过滤器:可以拿到原始的Http请求和响应的信息,只能获得其请求和响应携带的参数,但是却拿不到真正处理请求的控制器和方法的信息拦截器: 可以拿到原始Http请求和响应的信息 也可拿到请求的方法的信息切片 :可拿

使用CXF为webservice添加拦截器

拦截器分为Service端和Client端 拦截器是在发送soap消息包的某一个时机拦截soap消息包,对soap消息包的数据进行分析或处理.分为CXF自带的拦截器和自定义的拦截器 1.Service端: 通过将org.apache.cxf.jaxws.EndpointImpl类的方法即可实现   发布Web Service 方法可以通过Endpoint.publish()方法,此方法返为EndpointImpl,所以为Service端添加拦截器很简单. 部分代码: UserService us

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

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

Struts 2 之拦截器

拦截器概述 Struts2拦截器是在访问某个Action或Action的某个方法,字段之前或之后实施拦截,并且Struts2拦截器是可插拔的,拦截器是AOP(Aspect Oriented Programming,面向切面编程)的一种实现 拦截器栈(InterceptorStack).Struts2拦截器栈就是将拦截器按一定的顺序联结成一条链.在访问被拦截的方法或字段时,Struts2拦截器链中的拦截器就会按其之前定义的顺序被调用. Struts2规定用户自定义拦截器必须实现com.opensy

Struts2拦截器的使用 (详解)

这位仁兄的写的不错,我照抄过来了:http://www.blogjava.net/i369/articles/162407.html 如何使用struts2拦截器,或者自定义拦截器.特别注意,在使用拦截器的时候,在Action里面必须最后一定要引用struts2自带的拦截器缺省堆栈defaultStack,如下(这里我是引用了struts2自带的checkbox拦截器):<interceptor-ref name="checkbox">  <param name=&q