使用jaxws建立webservice客户端并实现soap消息的handler验证示例
这篇文章主要介绍了使用jaxws建立webservice客户端并实现soap消息的handler验证示例,需要的朋友可以参考下
因项目需要,将之前使用过的webservice重新捡了起来,并且这次选择了使用不需要jar包的Java原生Jaxws。首先是wsimport的用法,先分享我的用法:cmd下先转到工程所在路径,然后运行以下命令
代码如下:
wsimport -keep -extension -s ./src -p com.jaxws.test http://192.168.1.1:8080/service?wsdl
在com.jaxws.test的包下就能找到自动生成的各种客户端相关辅助类。这些类怎么用就不细说了,网上很多资料。然后就是自己编写调用类(我这里只是一个方法,会被调用到就行)
代码如下:
public String jaxws(Object[] opArgs)
{
ServicesService service=new ServicesService();
//向SOAP添加表头
service.setHandlerResolver(new HandlerResolver(){
public List<Handler> getHandlerChain(PortInfo portInfo) {
List<Handler> handlerList = new ArrayList<Handler>();
//添加认证信息
handlerList.add(new ClientHandler());
return handlerList;
}
});
String result =service.getServicesPort().getResults(opArgs.toString());
//得到结果
System.out.println(result);
return result;
}
注意到这里的【//添加认证信息 handlerList.add(new ClientHandler());】,所以我们还需要新建一个ClientHandler类来实现认证消息的组装,如下:
代码如下:
package com.jaxws.test;
import java.util.Set;
import javax.xml.namespace.QName;
import javax.xml.soap.*;
import javax.xml.ws.handler.MessageContext;
import javax.xml.ws.handler.soap.SOAPHandler;
import javax.xml.ws.handler.soap.SOAPMessageContext;
public class ClientHandler implements SOAPHandler<SOAPMessageContext> {
public boolean handleMessage(SOAPMessageContext ctx) {
//出站,即客户端发出请求前,添加表头信息
Boolean request_p=(Boolean)ctx.get(MessageContext.MESSAGE_OUTBOUND_PROPERTY);
if(request_p){
try {
SOAPMessage msg=ctx.getMessage();
SOAPEnvelope env=msg.getSOAPPart().getEnvelope();
SOAPHeader hdr=env.getHeader();
if(hdr==null) hdr=env.addHeader();
//添加认证信息头
//QName(String namespaceURI, String localPart, String prefix)
//QName(String namespaceURI, String localPart)
//QName(String localPart)
//@param namespaceURI:QName的名称空间
//@param localPart:QName的本地部分
//@param prefix:QName的前缀
QName name=new QName("http://csdc.info/", "Authentication", "wsse");
SOAPHeaderElement header = hdr.addHeaderElement(name);
//addChildElement(String localName, String prefix,String uri)
//addChildElement(String localName, String prefix)
//addChildElement(String localName)
//@param uri:新元素所属空间名称URI
//@param localName:新元素的本地名称
//@param prefix:新元素名称的空间前缀
//见JDK 1.6的API
SOAPElement userElement = header.addChildElement("Username", "wsse");
userElement.addTextNode("admin");
SOAPElement passElement = header.addChildElement("Password", "wsse");
passElement.addTextNode("admin");
msg.saveChanges();
//把SOAP消息输出到System.out,即控制台
msg.writeTo(System.out);
return true;
} catch (Exception e) {
e.printStackTrace();
}
}
return false;
}
@Override
public boolean handleFault(SOAPMessageContext context) {
// TODO Auto-generated method stub
return false;
}
@Override
public void close(MessageContext context) {
// TODO Auto-generated method stub
}
@Override
public Set<QName> getHeaders() {
// TODO Auto-generated method stub
return null;
}
}
这个类就把所有的soap消息都加上了一个头消息,我这里的头消息如下:
代码如下:
<wsse:Authentication xmlns:wsse="http://csdc.info/">
<wsse:Username>admin</wsse:Username>
<wsse:Password>admin</wsse:Password>
</wsse:Authentication>
这样就实现了带soap头认证的基于jaxws的webservice客户端。
精彩图集
精彩文章