這篇文章主要介紹“怎么使用axis調用WebService及Java WebService調用工具類”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“怎么使用axis調用WebService及Java WebService調用工具類”文章能幫助大家解決問題。
能使得運行在不同機器上的不同應用無須借助附加的、專門的第三方軟件或硬件,就可相互交換數據或集成。依據 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>
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 {
// 接口調用地址
private static String url = "http://127.0.0.1:8080/webservice.asmx";
// 命名空間
private static String namespace = "http://tempuri.org/";
/**
* WebService - 調用接口
*
* @param methodName 函數名
* @param params 參數
* @param clazz 返回對象class
* @return 返回結果(Object)
*/
public static <T> T call(String methodName, Map<String, String> params, Class<T> clazz) {
// log.info("調用 WebService 發送參數==>" + 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));
// 添加參數
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);
// 進行序列化 實體類也要序列化 implements Serializable
call.registerTypeMapping(clazz, new QName(namespace, soapActionURI),
new BeanSerializerFactory(clazz, new QName(namespace, soapActionURI)),
new BeanDeserializerFactory(clazz, new QName(namespace, soapActionURI)));
// 設置輸出的類
call.setReturnClass(clazz);
// 接口返回結果
T result = (T) call.invoke(parameterList.toArray());
log.info("調用 WebService 接口返回===>" + result);
return result;
} catch (Exception e) {
log.error("調用 WebService 接口錯誤信息==>" + e.getMessage());
}
return null;
}
/**
* WebService - 接口調用
*
* @param methodName 函數名
* @param params 參數
* @return 返回結果(String)
*/
public static String call(String methodName, Map<String, String> params) {
// log.info("調用 WebService 發送參數==>" + 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));
// 添加參數
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);
// 設置返回類型
call.setReturnType(new QName(namespace, methodName), String.class);
// 接口返回結果
String result = (String) call.invoke(parameterList.toArray());
log.info("調用 WebService 接口返回===>" + result);
return result;
} catch (Exception e) {
log.error("調用 WebService 接口錯誤信息==>" + e.getMessage());
}
return null;
}
/**
* WebService - 調用接口
*
* @param methodName 函數名
* @param params 參數
* @return 返回結果(String)
*/
public static String call2(String methodName, Map<String, String> params) {
// log.info("調用 WebService 發送參數==>" + 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));
// 添加參數
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);
// 設置返回類型
call.setReturnType(XMLType.XSD_SCHEMA);
// 接口返回結果
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("調用 WebService 接口返回===>" + result);
return result;
} catch (Exception e) {
log.error("調用 WebService 接口錯誤信息==>" + e.getMessage());
}
return null;
}
}第一個方法為返回對象的方式,區別在于需要定義返回對象,屬性值需要跟 WebService 中的返回對象保持一致。
第二個方法適用于調用 WebService后,返回的值為 String 類型。
參數詳解:
methodName:函數名。需要調用的 WebService 的函數名稱。
params:參數。調用 WebService 時需傳入的參數。
關于“怎么使用axis調用WebService及Java WebService調用工具類”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。