如何使用axis調(diào)用WebService及Java?WebService調(diào)用工具類
WebService 簡介
概述
能使得運(yùn)行在不同機(jī)器上的不同應(yīng)用無須借助附加的、專門的第三方軟件或硬件,就可相互交換數(shù)據(jù)或集成。依據(jù) WebService 規(guī)范實(shí)施的應(yīng)用之間,無論它們所使用的語言、平臺(tái)或內(nèi)部協(xié)議是什么,都可以相互交換數(shù)據(jù)。
也就是說可以實(shí)現(xiàn)多語言、跨平臺(tái)數(shù)據(jù)交互。
使用 axis 調(diào)用 WebService
引入依賴
pom.xml 依賴如下:
<dependency>
<groupId>org.apache.axis</groupId>
<artifactId>axis</artifactId>
<version>1.4</version>
</dependency>
<dependency>
<groupId>org.apache.axis</groupId>
<artifactId>axis-jaxrpc</artifactId>
<version>1.4</version>
</dependency>
<dependency>
<groupId>axis</groupId>
<artifactId>axis-wsdl4j</artifactId>
<version>1.5.1</version>
</dependency>
<dependency>
<groupId>commons-discovery</groupId>
<artifactId>commons-discovery</artifactId>
<version>0.2</version>
</dependency>
WebService 調(diào)用工具類
package com.micromaple.common.utils;
import com.google.common.collect.Lists;
import lombok.extern.slf4j.Slf4j;
import org.apache.axis.client.Call;
import org.apache.axis.client.Service;
import org.apache.axis.encoding.XMLType;
import org.apache.axis.encoding.ser.BeanDeserializerFactory;
import org.apache.axis.encoding.ser.BeanSerializerFactory;
import org.apache.axis.message.SOAPHeaderElement;
import org.apache.axis.types.Schema;
import org.apache.commons.collections.MapUtils;
import javax.xml.namespace.QName;
import javax.xml.rpc.ParameterMode;
import java.util.List;
import java.util.Map;
import java.util.Set;
/**
* WebService - 工具類
* Title: WebServiceUtils
* Description:
*
* @author Micromaple
* @version 1.0.0
* @date 2022/7/1 12:14
*/
@Slf4j
public class WebServiceUtils {
// 接口調(diào)用地址
private static String url = "http://127.0.0.1:8080/webservice.asmx";
// 命名空間
private static String namespace = "http://tempuri.org/";
/**
* WebService - 調(diào)用接口
*
* @param methodName 函數(shù)名
* @param params 參數(shù)
* @param clazz 返回對(duì)象class
* @return 返回結(jié)果(Object)
*/
public static <T> T call(String methodName, Map<String, String> params, Class<T> clazz) {
// log.info("調(diào)用 WebService 發(fā)送參數(shù)==>" + MapperUtils.mapToJson(params));
String soapActionURI = namespace + methodName;
try {
Service service = new Service();
SOAPHeaderElement header = new SOAPHeaderElement(namespace, methodName);
header.setNamespaceURI(namespace);
Call call = (Call) service.createCall();
call.setTargetEndpointAddress(url);
call.setOperationName(new QName(namespace, methodName));
// 添加參數(shù)
List<String> parameterList = Lists.newArrayList();
if (params != null) {
Set<String> paramsKey = params.keySet();
for (String key : paramsKey) {
call.addParameter(new QName(namespace, key), XMLType.XSD_STRING, ParameterMode.IN);
String pValue = MapUtils.getString(params, key);
header.addChildElement(key).setValue(pValue);
parameterList.add(pValue);
}
}
call.setUseSOAPAction(true);
call.setSOAPActionURI(soapActionURI);
call.addHeader(header);
// 進(jìn)行序列化 實(shí)體類也要序列化 implements Serializable
call.registerTypeMapping(clazz, new QName(namespace, soapActionURI),
new BeanSerializerFactory(clazz, new QName(namespace, soapActionURI)),
new BeanDeserializerFactory(clazz, new QName(namespace, soapActionURI)));
// 設(shè)置輸出的類
call.setReturnClass(clazz);
// 接口返回結(jié)果
T result = (T) call.invoke(parameterList.toArray());
log.info("調(diào)用 WebService 接口返回===>" + result);
return result;
} catch (Exception e) {
log.error("調(diào)用 WebService 接口錯(cuò)誤信息==>" + e.getMessage());
}
return null;
}
/**
* WebService - 接口調(diào)用
*
* @param methodName 函數(shù)名
* @param params 參數(shù)
* @return 返回結(jié)果(String)
*/
public static String call(String methodName, Map<String, String> params) {
// log.info("調(diào)用 WebService 發(fā)送參數(shù)==>" + MapperUtils.mapToJson(params));
String soapActionURI = namespace + methodName;
try {
Service service = new Service();
SOAPHeaderElement header = new SOAPHeaderElement(namespace, methodName);
header.setNamespaceURI(namespace);
Call call = (Call) service.createCall();
call.setTargetEndpointAddress(url);
call.setOperationName(new QName(namespace, methodName));
// 添加參數(shù)
List<String> parameterList = Lists.newArrayList();
if (params != null) {
Set<String> paramsKey = params.keySet();
for (String key : paramsKey) {
call.addParameter(new QName(namespace, key), XMLType.XSD_STRING, ParameterMode.IN);
String pValue = MapUtils.getString(params, key);
header.addChildElement(key).setValue(pValue);
parameterList.add(pValue);
}
}
call.setUseSOAPAction(true);
call.setSOAPActionURI(soapActionURI);
call.addHeader(header);
// 設(shè)置返回類型
call.setReturnType(new QName(namespace, methodName), String.class);
// 接口返回結(jié)果
String result = (String) call.invoke(parameterList.toArray());
log.info("調(diào)用 WebService 接口返回===>" + result);
return result;
} catch (Exception e) {
log.error("調(diào)用 WebService 接口錯(cuò)誤信息==>" + e.getMessage());
}
return null;
}
/**
* WebService - 調(diào)用接口
*
* @param methodName 函數(shù)名
* @param params 參數(shù)
* @return 返回結(jié)果(String)
*/
public static String call2(String methodName, Map<String, String> params) {
// log.info("調(diào)用 WebService 發(fā)送參數(shù)==>" + MapperUtils.mapToJson(params));
String soapActionURI = namespace + methodName;
try {
Service service = new Service();
SOAPHeaderElement header = new SOAPHeaderElement(namespace, methodName);
header.setNamespaceURI(namespace);
Call call = (Call) service.createCall();
call.setTargetEndpointAddress(url);
call.setOperationName(new QName(namespace, methodName));
// 添加參數(shù)
List<String> parameterList = Lists.newArrayList();
if (params != null) {
Set<String> paramsKey = params.keySet();
for (String key : paramsKey) {
call.addParameter(new QName(namespace, key), XMLType.XSD_STRING, ParameterMode.IN);
String pValue = MapUtils.getString(params, key);
header.addChildElement(key).setValue(pValue);
parameterList.add(pValue);
}
}
call.setUseSOAPAction(true);
call.setSOAPActionURI(soapActionURI);
call.addHeader(header);
// 設(shè)置返回類型
call.setReturnType(XMLType.XSD_SCHEMA);
// 接口返回結(jié)果
Schema schemaResult = (Schema)call.invoke(parameterList.toArray());
String result = "";
for(int i = 0; i<schemaResult.get_any().length; i++){
result = result + schemaResult.get_any()[i];
}
log.error("調(diào)用 WebService 接口返回===>" + result);
return result;
} catch (Exception e) {
log.error("調(diào)用 WebService 接口錯(cuò)誤信息==>" + e.getMessage());
}
return null;
}
}
- 第一個(gè)方法為返回對(duì)象的方式,區(qū)別在于需要定義返回對(duì)象,屬性值需要跟
WebService中的返回對(duì)象保持一致。 - 第二個(gè)方法適用于調(diào)用
WebService后,返回的值為String類型。
參數(shù)詳解:
methodName:函數(shù)名。需要調(diào)用的WebService的函數(shù)名稱。params:參數(shù)。調(diào)用WebService時(shí)需傳入的參數(shù)。
總結(jié)
到此這篇關(guān)于如何使用axis調(diào)用WebService及Java WebService調(diào)用工具類的文章就介紹到這了,更多相關(guān)axis調(diào)用WebService內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
intellij idea如何配置網(wǎng)絡(luò)代理
intellij idea所在的這臺(tái)電腦本身上不了網(wǎng),要通過代理上網(wǎng),那么intellij idea怎么設(shè)置代理上網(wǎng)呢?今天通過本文給大家分享intellij idea如何配置網(wǎng)絡(luò)代理,感興趣的朋友一起看看吧2023-10-10
Intellij IDEA導(dǎo)入eclipse web項(xiàng)目的操作步驟詳解
Eclipse當(dāng)中的web項(xiàng)目都會(huì)有這兩個(gè)文件,但是idea當(dāng)中應(yīng)該是沒有的,所以導(dǎo)入會(huì)出現(xiàn)兼容問題,但是本篇文章會(huì)教大家如何導(dǎo)入,并且導(dǎo)入過后還能使用tomcat運(yùn)行,需要的朋友可以參考下2023-08-08
Spring中@Import的各種用法以及ImportAware接口詳解
這篇文章主要介紹了Spring中@Import的各種用法以及ImportAware接口詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10
Springboot集成knife4j實(shí)現(xiàn)風(fēng)格化API文檔
這篇文章主要介紹了Springboot如何集成knife4j實(shí)現(xiàn)風(fēng)格化API文檔,幫助大家更好的使用springboot框架,感興趣的朋友可以了解下2020-12-12
解決SpringMVC同時(shí)接收J(rèn)son和Restful時(shí)Request里有Map的問題
今天小編就為大家分享一篇解決SpringMVC同時(shí)接收J(rèn)son和Restful時(shí)Request里有Map的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-08-08
Java如何實(shí)現(xiàn)http接口參數(shù)和返回值加密
這篇文章主要介紹了Java如何實(shí)現(xiàn)http接口參數(shù)和返回值加密問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11
MyBatis不同Mapper文件引用resultMap實(shí)例代碼
這篇文章主要介紹了mybatis 不同Mapper文件引用resultMap的實(shí)例代碼,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下2017-07-07
Java實(shí)現(xiàn)Web應(yīng)用中的定時(shí)任務(wù)(實(shí)例講解)
下面小編就為大家分享一篇Java實(shí)現(xiàn)Web 應(yīng)用中的定時(shí)任務(wù)的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2017-11-11

