優勢:用ducument方式應用現對繁瑣而靈活。如今用的比較多。由於真正擺脫了咱們不想要的耦合java
代碼:node
public void addValidation(ServiceClient serviceClient, String tns , String token_str) { //建立的頭結構,因你的需求不一樣,能夠參考底部的圖來對應具體的xml結構 OMFactory fac = OMAbstractFactory.getOMFactory(); OMNamespace omNs = fac.createOMNamespace(tns, ""); OMElement header = fac.createOMElement("AuthorizationSoapHeader", omNs); OMElement token = fac.createOMElement("MDIP_ACCESSTOKEN", omNs); //token.setText(token_str); token.addChild(fac.createOMText(token, token_str)); header.addChild(token); serviceClient.addHeader(header); } public void init() { try { String inp_no = this.getParameters(null)[0].getValue().toString(); String url = "http://xxxxx/services/select_v_inp_mr_page_list?wsdl"; // assign WebService url EndpointReference targetEPR = new EndpointReference(url); Options options = new Options(); options.setTo(targetEPR); // 命名空間/方法 拼接起來 options.setAction("http://datareceive.service.esb.medata.com/dataReceive"); // create request建立請求 ServiceClient sender = new ServiceClient(); sender.setOptions(options); //添加請求頭,不少時候把鑑權的信息放在請求頭裏 FR_AXIS2_WS se = new FR_AXIS2_WS(); se.addValidation(sender, "http://xxxxxxxxx.medata.com/", "B298CC760A2F2D09CEC6929D6F6D2190"); System.out.println (111); // create an OMFactory,it control namespace,method and parameter OMFactory fac = OMAbstractFactory.getOMFactory(); // namespace 命名空間 OMNamespace omNs = fac.createOMNamespace("http://xxxxxx.esb.medata.com/", ""); // method 要調用的方法 OMElement method = fac.createOMElement("dataReceive", omNs); // 對應方法名 //method's parameter 方法的參數 QName qname = new QName("param"); OMElement para_name = fac.createOMElement(qname);//fac.createOMElement("",omNs); //參數的值 para_name.setText(""+inp_no+""); method.addChild(para_name); method.build(); OMElement result1 = sender.sendReceive(method); /*根據你的需求解析xml。。不須要的小夥伴能夠不看下面*/ System.out.println(result1.getFirstElement().getText()); System.out.println(result1.getFirstElement().getLocalName()); String xml = "" + result1.getFirstElement().getText() ; System.out.println(xml); Document doc = DocumentHelper.parseText(xml); Element rootElt = doc.getRootElement(); Listnodes = rootElt.elements(); String RETURNCODE = nodes.get(0).getText(); String ERRORMEG = nodes.get(1).getText(); Listitem_nodes = nodes.get(2).elements(); String name = null; int index = 0; String[] cols = this.columnNames; Object[][] datas = new Object[item_nodes.size()][cols.length]; for (Element item:item_nodes) { for(int i =0;i<cols.length;i++) {="" system.out.println(cols[i]);="" name="item.element(cols[i]).getText();" system.out.println("xxxx:"+name+",item_nodes.size():"+item_nodes.size());="" datas[index][i]="item.element(cols[i]).getText();" }="" index++;="" listinfo_nodes = item.elements(); // for(Element node : info_nodes){ // System.out.println(node.getName()+":"+node.getText()); // // } } System.out.println("bbb:"+datas[0][0]); int a1 = (int)(100*Math.random()); //String[] columnNames = {"NAMES","SCORE","init_method"}; // Object[][] datas = {{"Alex", a1,11}, // {"Helly", 1112,23}, {"bob", 99,name}};//result1.getFirstElement().getText() this.columnNames = columnNames; this.rowData = datas; } catch (AxisFault axisFault) { axisFault.printStackTrace(); } catch (DocumentException e) { e.printStackTrace(); } }
wsdl文件打開後的webservice說明:web
關於建立命名空間時的第二個參數後綴dom
OMNamespace omNs = fac.createOMNamespace(tns, "");
圖中targetNames就是命名空間。ide
若是加了第二個參數會出現什麼樣子呢?我就是由於加了這個東西,而服務端沒有對這個 後綴的解析,致使一直調不通服務。ui
例如OMNamespace omNs = fac.createOMNamespace(tns, "dsp");
首先放一段我本身的請求報文(上圖)。紅框內的xmlns就是命名空間,若是createOMNamespace(tns, "dsp"); 這個方法來建立,則會變成xmlns:dsp=""this
<soapenv:Header> <AuthorizationSoapHeader xmlns:dsp="http://xxxxxxxxx.medata.com/"> <MDIP_ACCESSTOKEN>B298CC760A2F2D09CEC6929D6F6D2190</MDIP_ACCESSTOKEN> </AuthorizationSoapHeader> </soapenv:Header>
這就是區別。url