Asp.NET Core 如何調(diào)用WebService的方法
0.使用背景
因?yàn)楝F(xiàn)在的項(xiàng)目都是基于 .NET Core 的,但是某些需要調(diào)用第三方的 WebService 服務(wù),故有了此文章。其基本思路是通過(guò)微軟提供的 Svcutil 工具生成代理類(lèi),然后通過(guò) System.ServiceModel 來(lái)調(diào)用代理類(lèi)所提供的對(duì)象與方法。
1.配置準(zhǔn)備
1.1 新建并編輯項(xiàng)目
首先新建一個(gè)新的 .NET Core 控制臺(tái)程序,通過(guò)命令行窗口或者 Powershell 執(zhí)行以下命令新建一個(gè)項(xiàng)目。
dotnet new console

然后編輯項(xiàng)目文件 WebServiceConsole.csproj ,并在其中加入以下內(nèi)容:
<ItemGroup> <DotNetCliToolReference Include="dotnet-svcutil" Version="1.0.*" /> </ItemGroup>
這樣最終 WebServiceConsole.csproj 的內(nèi)容會(huì)是這樣子的。
<Project Sdk="Microsoft.NET.Sdk"> <PropertyGroup> <OutputType>Exe</OutputType> <TargetFramework>netcoreapp2.1</TargetFramework> </PropertyGroup> <ItemGroup> <DotNetCliToolReference Include="dotnet-svcutil" Version="1.0.*" /> </ItemGroup> </Project>
繼續(xù)打開(kāi)命令行窗口或者 Powershell 執(zhí)行以下命令,還原項(xiàng)目文件的包。
dotnet restore

1.2 代理類(lèi)生成
現(xiàn)在準(zhǔn)備工作做好了,現(xiàn)在我們可以使用 dotnet svcutil 命令來(lái)生成代理類(lèi),或者你可以到 WindowsSDKs 的目錄下找到 SvcUtil.exe 來(lái)執(zhí)行代理類(lèi)生成操作。
dotnet svcutil [WebService 地址]
上面是命令格式,比如說(shuō)我這里有一個(gè) WebService 提供的接口,其地址為 http://localhost:3000/bsp-oisp/ws/sfexpressService?wsdl ,那么我們需要打開(kāi)命令行工具,執(zhí)行以下命令來(lái)生成代理類(lèi)。

成功之后會(huì)看到文件夾里面多了一個(gè)文件夾。
注意,在生成代理類(lèi)之后,我們還需要再執(zhí)行一次 dotnet restore 來(lái)還原代理類(lèi)當(dāng)中所使用到的 NuGet 包。
2.調(diào)用 WebService 接口
生成代理類(lèi)之后,重新打開(kāi)項(xiàng)目,可以看到多了一個(gè) ServiceModel1 的文件夾,在里面還有一個(gè) Reference.cs 的文件,這個(gè)文件里面的內(nèi)容就是根據(jù)我們之前提供的 Url 生成的代理類(lèi)了。
用法的話很簡(jiǎn)單,需要三步,在這里我直接在 Main() 方法內(nèi)部寫(xiě)調(diào)用方法了,注意這里基本上所有生成的方法都是異步方法。
using System;
using System.ServiceModel;
using System.Threading.Tasks;
namespace WebServiceConsole
{
class Program
{
static async Task Main(string[] args)
{
// 創(chuàng)建 HTTP 綁定對(duì)象
var binding = new BasicHttpBinding();
// 根據(jù) WebService 的 URL 構(gòu)建終端點(diǎn)對(duì)象
var endpoint = new EndpointAddress(@" http://localhost:3000/bsp-oisp/ws/sfexpressService?wsdl](http://localhost:3000/bsp-oisp/ws/sfexpressService?wsdl");
// 創(chuàng)建調(diào)用接口的工廠,注意這里泛型只能傳入接口
var factory = new ChannelFactory<IExpressService>(binding, endpoint);
// 從工廠獲取具體的調(diào)用實(shí)例
var callClient = factory.CreateChannel();
// 調(diào)用具體的方法,這里是 sfexpressServiceAsync 方法。
var result = await callClient.sfexpressServiceAsync(new sfexpressService());
Console.ReadLine();
}
}
}
3.注意事項(xiàng)
報(bào)文長(zhǎng)度問(wèn)題,我在call 一個(gè)QAS service時(shí),因?yàn)閳?bào)文過(guò)長(zhǎng),出過(guò)錯(cuò)誤,所以報(bào)文長(zhǎng)度最好手動(dòng)設(shè)置一下,防止默認(rèn)長(zhǎng)度不夠(默認(rèn)長(zhǎng)度我測(cè)試是65536)。
binding.MaxReceivedMessageSize=2000000
https需要設(shè)置。代碼如下:
channelFactory.Credentials.ServiceCertificate.SslCertificateAuthentication =
new X509ServiceCertificateAuthentication()
{
CertificateValidationMode = X509CertificateValidationMode.None,
RevocationMode = X509RevocationMode.NoCheck
};
在call某些特殊的Web Service時(shí),生成的代理類(lèi)model無(wú)法解析服務(wù)返回報(bào)文,這種情況我只在Call QAS時(shí)遇到,在這里就詳細(xì)描述下問(wèn)題,QAS是一個(gè)國(guó)外提供地址校驗(yàn)的服務(wù)提供商,我們用他們提供的一個(gè)軟件安裝后生成的Web Service服務(wù)在轉(zhuǎn)發(fā)到他們自己的服務(wù)上。所以在生成代理類(lèi)的時(shí)候,就出現(xiàn)生成代理類(lèi)里面的model無(wú)法解析他的返回報(bào)文,經(jīng)過(guò)查閱代理類(lèi)代碼,發(fā)現(xiàn)他在生成返回報(bào)文的model中,返回字段有些會(huì)加上一個(gè)特性標(biāo)記,而這些標(biāo)記是錯(cuò)誤的,所以只要去掉就行。
例:
[System.Xml.Serialization.XmlElementAttribute(Order=0)]
public string Country { get; set; }
Update如下即可
public string Country { get; set; }
4.參考資料:
https://docs.microsoft.com/en-us/dotnet/core/additional-tools/dotnet-svcutil-guide
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
實(shí)現(xiàn)DataGridView控件中CheckBox列的使用實(shí)例
最近做WindowsForms程序,使用DataGridView控件時(shí),加了一列做選擇用,發(fā)現(xiàn)CheckBox不能選中。搜索后,要實(shí)現(xiàn)DataGridView的CellContentClick事件,將代碼貼一下2014-01-01
asp.net 日期函數(shù) 某月的第一天和最后一天的日期
常用asp.net日期操作函數(shù)-得到某月的第一天和最后一天的日期2008-12-12
ASP.NET與ASP互通COOKIES的一點(diǎn)經(jīng)驗(yàn)
ASP與ASP.NET互相整合時(shí),其中文COOKIES信息無(wú)法被互通共享,當(dāng)使用ASP.NET寫(xiě)入中文COOKIES信息后,使用ASP進(jìn)行讀取,讀出來(lái)的卻是亂碼,而非中文。2010-03-03
ASP.NET MVC重寫(xiě)RazorViewEngine實(shí)現(xiàn)多主題切換
這篇文章主要為大家詳細(xì)介紹了ASP.NET MVC重寫(xiě)RazorViewEngine實(shí)現(xiàn)多主題切換,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06
基于ASP.NET Core數(shù)據(jù)保護(hù)生成驗(yàn)證token示例
本篇文章主要介紹了基于ASP.NET Core數(shù)據(jù)保護(hù)生成驗(yàn)證token,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-02-02

