使用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 getHandlerChain(PortInfo portInfo) {
            List handlerList = new ArrayList();
            //添加认证信息
            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 {

    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 getHeaders() {
        // TODO Auto-generated method stub
        return null;
    }
}

 这个类就把所有的soap消息都加上了一个头消息,我这里的头消息如下:
复制代码 代码如下:


    admin
    admin


这样就实现了带soap头认证的基于jaxws的webservice客户端。

你可能感兴趣的:(使用jaxws建立webservice客户端并实现soap消息的handler验证示例)