狠狠色丁香婷婷综合尤物/久久精品综合一区二区三区/中国有色金属学报/国产日韩欧美在线观看 - 国产一区二区三区四区五区tv

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

【C#】快速實(shí)現(xiàn).NET(.net framework/.net core+)動態(tài)訪問webservice服務(wù)

admin
2024年6月19日 18:57 本文熱度 1166

前言:訪問webservice,大多數(shù)人都是用服務(wù)引用的方式,但是這種方式比較麻煩,例如遇到服務(wù)更新了,你還需要手動更新你的服務(wù)引用,再重新發(fā)布,很麻煩。或者已有的一些例子,至少我看到的很多案例,動態(tài)訪問也只能止步于使用.net framework環(huán)境,沒看到有啥.net core上面動態(tài)訪問的案例。于是我就來拋磚引玉一下,自己寫一個支持.net framework也可以支持.netcore或以上環(huán)境使用的動態(tài)訪問webservice服務(wù)接口的方法,供大家使用或參考。

先創(chuàng)建一個webservice服務(wù),用來測試使用。提供三個服務(wù)接口,一個無參數(shù)、一個字符串參數(shù)、一個含有多個實(shí)體類參數(shù)(實(shí)體類參數(shù)也含有嵌套和集合)以及返回帶有嵌套和集合的返回?cái)?shù)據(jù),用來做測試使用,基本上可以涵蓋幾乎所有的webservice服務(wù)的情況了。

有關(guān)測試實(shí)體類

啟動webservice服務(wù)備用

請求端程序,支持.netframework 4.6.1+、.net core+和.net 5+所有版本,都可以通過nuget來引用 Wesky.Net.OpenTools 包。需要引用最新的版本,以保證功能完善。我此處使用.net 8的控制臺來引用,大佬們可以根據(jù)自己程序情況進(jìn)行引用,framework4.6以下版本不適用。

為了方便使用,我本地也直接編寫幾個實(shí)體類,用來傳參和做返回值接收使用:

先實(shí)例化一個WebserviceHelper對象,如果有用IOC容器的大佬,比如說使用asp.net core程序等,可以對該接口和類進(jìn)行依賴注入的注冊。如果沒用IOC容器的大佬,可以直接這樣new一個使用。此處我用new一個對象的使用方式來使用。并且獲取到asmx的url地址,地址此處需要添加?wsdl后綴。

申明要訪問的服務(wù)的名稱,例如HelloWorld,然后直接調(diào)用。由于沒有參數(shù),所以參數(shù)直接設(shè)為null

運(yùn)行程序進(jìn)行調(diào)用,可以看到獲取到了返回值的xml文檔。

直接調(diào)用的時(shí)候,返回值是一個 OpenToolResult類型,類型定義如下:

由于咱們的返回值就一個基礎(chǔ)類型string,所以需要調(diào)用解析基礎(chǔ)類型值的方法,得到最終的返回消息為 Hello World。

基礎(chǔ)類型值解析方法定義如下:

傳入?yún)?shù)為:獲取到的返回值、節(jié)點(diǎn)名稱(一般是方法名稱+“Result”)、命名空間,命名空間在調(diào)用的時(shí)候,會被存儲到類型OpenWebserviceInfo的屬性O(shè)penWebservice集合(是一個OpenWebserviceDocCache類型的集合)里面去,通過url地址和接口方法名字可以匹配到對應(yīng)的命名空間。

OpenWebserviceDocCache類型定義如下:

接著試一下傳入一個基礎(chǔ)類型參數(shù)的情況。訪問Hola方法,傳入Wesky字符串,成功獲取到返回值 Wesky World。

接下來試一下傳入多個實(shí)體類參數(shù),并且按照上面webservice的內(nèi)容,會返回一個其他一個實(shí)體類消息。

回看一下TestService服務(wù)接口的實(shí)現(xiàn),說明動態(tài)訪問是成功的。

訪問webservice方法定義說明。參數(shù)可以傳0個或多個參數(shù),會用來和解析度wsdl地址的同名方法服務(wù)參數(shù)個數(shù)做匹配,如果不匹配,則會提示錯誤信息。返回值Result.IsSuccess如果是true,代表發(fā)送請求成功;如果解析錯誤或者發(fā)送請求失敗等,則提示false,并且Message屬性會有具體錯誤信息描述。

返回值為實(shí)體類的解析方法定義說明。以上請求TestSevice服務(wù)接口時(shí)候,返回值是實(shí)體類,如果需要匹配本地的實(shí)體類,需要訪問 ExtractCustomerValueFromXml方法進(jìn)行解析處理。例如上面?zhèn)魅氲氖荝esultInfo類型作為返回值接收類。

一些核心代碼:

/// <summary>

/// 調(diào)用Web服務(wù)

/// Calls a web service.

/// </summary>

/// <param name="url">服務(wù)URL / Service URL</param>

/// <param name="apiName">API名稱 / API name</param>

/// <param name="expireSecond">過期時(shí)間(秒)/ Expiration time in seconds</param>

/// <param name="parameters">調(diào)用參數(shù) / Invocation parameters</param>

/// <returns>調(diào)用結(jié)果 / Invocation result</returns>

public OpenToolResult<string> CallWebservice(string url, string apiName,long expireSecond = 86400,params object[] parameters)

{

    OpenToolResult<string> result = new HttpExtensions.OpenToolResult<string>();


    CheckExpireTime(url, apiName, expireSecond);


    var wsInfo = OpenWebserviceInfo.OpenWebservice.FirstOrDefault(x => x.WebserviceUrl == url && x.OperationName == apiName);


    if (wsInfo == null)

    {

        result.IsSuccess = false;

        result.Message = "本地?zé)o法加載遠(yuǎn)程webservice服務(wù)。Cannot load the remote webservice locally.";

        return result;

    }


    if ((parameters == null && wsInfo.ParameterNames.Count > 0) || (parameters!=null && parameters.Length != wsInfo.ParameterNames.Count))

    {

        result.IsSuccess = false;

        result.Message = $"遠(yuǎn)程服務(wù)接口參數(shù)個數(shù)和你傳入的參數(shù)個數(shù)不匹配。遠(yuǎn)程服務(wù)參數(shù)個數(shù):{wsInfo.ParameterNames.Count}, 本地傳入?yún)?shù)個數(shù):{parameters?.Length ?? 0}。Parameter count mismatch: remote service has {wsInfo.ParameterNames.Count}, provided {parameters?.Length ?? 0}.";

        return result;

    }



    Dictionary<string, string> dicParams = new Dictionary<string, string>();

    if (parameters != null)

    {

        for (int i = 0; i < wsInfo.ParameterNames.Count; i++)

        {

            dicParams.Add(wsInfo.ParameterNames[i], XmlConvertor.SerializeObjectToXml(parameters[i]));

        }

    }

    var response = InvokeService(url, apiName, dicParams,wsInfo.Namespace);


    result.Result = response;

    result.IsSuccess = true;

    result.Message = "success";


    return result;

}


該文章在 2024/6/19 18:57:08 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉儲管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved