利用Jaxws建立webservice客户端并成功实现soap消息的handler验证

因项目需要,将之前使用过的webservice重新捡了起来,并且这次选择了使用不需要jar包的Java原生Jaxws。首先是wsimport的用法,先分享我的用法:cmd下先转到工程所在路径,然后运行以下命令

1
wsimport -keep -extension -s ./src -p com.jaxws.test http://192.168.1.1:8080/service?wsdl

 在com.jaxws.test的包下就能找到自动生成的各种客户端相关辅助类。这些类怎么用就不细说了,网上很多资料。然后就是自己编写调用类(我这里只是一个方法,会被调用到就行)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
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类来实现认证消息的组装,如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
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消息都加上了一个头消息,我这里的头消息如下:

1
2
3
4
<wsse:Authentication xmlns:wsse="http://csdc.info/">
    <wsse:Username>admin</wsse:Username>
    <wsse:Password>admin</wsse:Password>
</wsse:Authentication>

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

利用Jaxws建立webservice客户端并成功实现soap消息的handler验证,古老的榕树,5-wow.com

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。