【CXF】- 拦截器 Interceptor
CXF拦截器
拦截动态操作请求和响应数据
拦截器分类
位置:服务器端拦截器,客户端拦截器
消息方向:入拦截器 出拦截器
定义者:系统拦截器 自定义拦截器:LoggingInInteceptor
①:创建webservice服务端的自定义入拦截器,用于检查客户端传入的参数:
package com.zhiwei.ws.imp;
import java.util.List;
import org.apache.cxf.binding.soap.SoapHeader;
import org.apache.cxf.binding.soap.SoapMessage;
import org.apache.cxf.headers.Header;
import org.apache.cxf.interceptor.Fault;
import org.apache.cxf.phase.AbstractPhaseInterceptor;
import org.apache.cxf.phase.Phase;
import org.w3c.dom.Element;
public class DefineInterceptor extends AbstractPhaseInterceptor<SoapMessage> {
public DefineInterceptor() {
super(Phase.PRE_PROTOCOL);
}
//<head> <name>zhiwei<name></head>
@Override
public void handleMessage(SoapMessage msg) throws Fault {
//获取文件头
List<Header> headers=msg.getHeaders();
SoapHeader header=(SoapHeader) headers.get(0);
Element element=(Element) header.getObject();
String name=element.getElementsByTagName("name").item(0).getTextContent();
if("xiaoyang".equals(name)) {
System.out.println("Server interceptor.........."+name);
return;
}
throw new Fault(new RuntimeException("用户名不正确!"));
}
}
②:配置服务端的拦截器:引入CXF实现的日志记录拦截器,启动服务端
String address = "http://localhost:8888/webservice";
// 终端发布web服务:SEI实现类
Endpoint endpoint = Endpoint.publish(address, new HelloWSImp());
// 终端控制拦截器
EndpointImpl endpointImpl = (EndpointImpl) endpoint;
// 配置入拦截器:将拦截器加入到拦截器集合:日志拦截器
List<Interceptor<? extends Message>> inIterceptors = endpointImpl.getInInterceptors();
inIterceptors.add(new LoggingInInterceptor());
inIterceptors.add(new DefineInterceptor());
List<Interceptor<? extends Message>> outIterceptors = endpointImpl.getOutInterceptors();
outIterceptors.add(new LoggingOutInterceptor());
System.out.println("server is deploying!");
服务端控制台日志:
③:创建客户端自定义拦截器
package com.zhiwei.ws.client;
import java.util.List;
import javax.xml.namespace.QName;
import org.apache.cxf.binding.soap.SoapMessage;
import org.apache.cxf.headers.Header;
import org.apache.cxf.interceptor.Fault;
import org.apache.cxf.phase.AbstractPhaseInterceptor;
import org.apache.cxf.phase.Phase;
import org.apache.xml.utils.www.dashuju2.cn DOMHelper;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
@SuppressWarnings("deprecation"www.yongshi123.cn)
public class DefineInterceptor extends AbstractPhaseInterceptor<SoapMessage> {
private String name;
public DefineInterceptor(String name) {
super(Phase.PRE_PROTOCOL); // 准备协议时拦截
this.name = name;
}
/*
* <Envelop> <head> <name>zhiwei<name> </head> <soapenv:Body> <q0:sayHello>
* <arg0>china</arg0> <www.jiahuayulpt.com www.yongshiyule178.com /q0:sayHello> </soapenv:Body> </Envelop>
*/
@Override
public void handleMessage(SoapMessage msg) throws Fault {
List<Header> headers=msg.getHeaders(www.dfgjpt.com ); //获取soap的头信息
/* soap消息头:
* <head>
* <zhiwei>
* <name>zhiwei<name>
* <zhiwei>
* </head>
*/
Document document=DOMHelper.createDocument();
Element root=document.createElement(www.enzuovip.com"zhiwei");
//Qname给标签添加一个独一无二的名字:类似别名
Element element=document.createElement("name");
element.setTextContent(name);
root.appendChild(element);
headers.add(new Header(new www.furongpt.com QName("root"), root));
System.out.println("DefineInterceptor Interceptor:--------->running!");
}
}
④:配置客户端拦截器,并且启动客户端
HelloWSImpService helloWSImpService=new HelloWSImpService();
HelloWS helloWS=helloWSImpService.getHelloWSImpPort();
//返回服务类的代理接口
Client client=ClientProxy.getClient(www.maituyul1.cn helloWS);
List<Interceptor<? extends Message>> outIterceptors=client.getOutInterceptors();
outIterceptors.add(new DefineInterceptor(www.modeng2yuL.cn"xiaoyang"));
String result=helloWS.sayHello("--->China!www.boyunylpt1.com");
System.out.println(result);
客户端控制台日志:
服务端控制台日志:
分析:服务端日志明显可看出,webservice是根据soap协议进行通信,并且服务端客户端配置的 拦截器都实现了拦截功能
SOAP: 特殊形式的Http请求形式
【CXF】- 拦截器 Interceptor的更多相关文章
- CXF拦截器(Interceptor)LoggingInInterceptor
Interceptor是CXF架构中一个重要的功能.你可以在不对核心模块进行修改的情况下,动态添加很多功能(你可以想象Struts2拦截器的优点).这对于CXF这个以处理消息为中心的服务框架来说是非常 ...
- Web Service学习之七:CXF拦截器
一.用途 CXF拦截器类似Struts2的拦截器,后者是拦截和处理请求,前者是对发送和接收的sope消息进行处理,一般用于WS请求响应中的权限验证.日志记录,Soap消息处理,消息的压缩处理等: 这个 ...
- CXF 入门:创建一个基于SOAPHeader的安全验证(CXF拦截器使用)
CXF拦截器使用,创建一个使用SOAPHeader的安全验证xml格式: <soap:Header> <auth:authentication xmlns:auth="ht ...
- struts2学习笔记--拦截器(Interceptor)和登录权限验证Demo
理解 Interceptor拦截器类似于我们学过的过滤器,是可以在action执行前后执行的代码.是我们做web开发是经常使用的技术,比如权限控制,日志.我们也可以把多个interceptor连在一起 ...
- struts2拦截器interceptor的三种配置方法
1.struts2拦截器interceptor的三种配置方法 方法1. 普通配置法 <struts> <package name="struts2" extend ...
- SSM-SpringMVC-33:SpringMVC中拦截器Interceptor讲解
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 拦截器Interceptor: 对处理方法进行双向的拦截,可以对其做日志记录等 我选择的是实现Handler ...
- 过滤器(Filter)和拦截器(Interceptor)
过滤器(Filter) Servlet中的过滤器Filter是实现了javax.servlet.Filter接口的服务器端程序.它依赖于servlet容器,在实现上,基于函数回调,它可以对几乎所有请求 ...
- 二十五、过滤器Filter,监听器Listener,拦截器Interceptor的区别
1.Servlet:运行在服务器上可以动态生成web页面.servlet的声明周期从被装入到web服务器内存,到服务器关闭结束.一般启动web服务器时会加载servelt的实例进行装入,然后初始化工作 ...
- Flume 拦截器(interceptor)详解
flume 拦截器(interceptor)1.flume拦截器介绍拦截器是简单的插件式组件,设置在source和channel之间.source接收到的事件event,在写入channel之前,拦截 ...
随机推荐
- Eclipse-设置启动JDK版本
打开eclipse安装目录下的eclipse.ini文件,将红色内容加入 -vm ../Java/jdk1.6.0_26/bin (或者指向具体目录:D:/software/jdk_1.8u91/bi ...
- Multi account chang login with multi -thread
void worker_DoWork(object sender, DoWorkEventArgs e) { isBussy = true; if (Common.isChangingAccount) ...
- 20155206赵飞 基于《Arm试验箱的国密算法应用》课程设计个人报告
20155206赵飞 基于<Arm试验箱的国密算法应用>课程设计个人报告 课程设计中承担的任务 完成试验箱测试功能1,2,3 . 1:LED闪烁实验 一.实验目的 学习GPIO原理 ...
- 20155207 《网络对抗》 Exp9 Web安全基础
20155207 <网络对抗> Exp9 Web安全基础 实验内容 关于WebGoat Cross-Site Scripting(XSS)练习 Injection Flaws练习 CSRF ...
- WPF编程,指定窗口图标、窗口标题,使得在运行状态下任务栏显示窗口图标的一种方法。
原文:WPF编程,指定窗口图标.窗口标题,使得在运行状态下任务栏显示窗口图标的一种方法. 版权声明:我不生产代码,我只是代码的搬运工. https://blog.csdn.net/qq_4330793 ...
- Node.js 下载路径/微软产品下载路径
https://nodejs.org/en/ https://www.microsoft.com/en-us/download //微软官方下载地址,可以下载VS2015 SQL 等 微软产品
- 如何取得Oracle并行执行的trace
如何取得Oracle并行执行的trace: ALTER SESSION SET tracefile_identifier='10046_PROD';ALTER SESSION SET max_dump ...
- 2_C语言中的数据类型 (十)数组
1 字符串与字符数组 1.1 字符数组定义 char array[100]; 1.2 字符数组初始化 char array[100] = {'a', 'b', ...
- Python RASP 工程化:一次入侵的思考
前言 今天讲的内容会很深,包括一些 Python的高级用法和一些自己创造的黑科技,前半部分内容你们可能听过,后半部分内容就真的是黑科技了... 深入的研究和思考,总会发现很多有意思的东西.每一次的研究 ...
- PAT-1004 Counting Leaves
1004 Counting Leaves (30 分) A family hierarchy is usually presented by a pedigree tree. Your job is ...