在.net 6.0中 调用远程服务器web服务,Webservices(xxx.asmx) ,RESTful 风格,2种解决方案。

1.使用 Connected Services**:**

  • 右键单击您的项目,选择 "Add"(添加)-> "Connected Services"(已连接的服务)。

  • 在 "Connected Services" 对话框中,选择 "WCF Web Service"。

  • 在 "WCF Web Service" 对话框中,输入 xxx.asmx 的 URL 地址(例如:http://A.B.C.com/ABCWebService/product/ProductService.asmx),然后点击"转到",然后在点击下方服务中的xxxSoap,右边操作框里面会显示所有方法,然后在输入一个命名空间(例如:CBEC.Web.ProductWebService),然后点击 "下一步"(前往)。截图如下:

  • Visual Studio 将会获取 xxx.asmx 中的方法列表。选择您想要添加的方法,然后点击 "Finish"(完成)。

  • Visual Studio 将为您生成一个代理类,该代理类包含远程服务器上的方法,您可以像调用本地方法一样使用这些方法。

示例代码:

cs 复制代码
using System;
using System.Threading.Tasks;
using YourServiceReference; // 请将 YourServiceReference 替换为实际的服务引用名称

class Program
{
    static async Task Main()
    {
        // 创建服务引用的客户端
        var client = new HuiLvServiceSoapClient(HuiLvServiceSoapClient.EndpointConfiguration.HuiLvServiceSoap);

        // 调用远程服务器的方法
        var result = await client.YourRemoteMethodAsync(param1, param2);
        
        // 处理返回的结果
        Console.WriteLine(result);
    }
}

2.使用 HTTP 客户端:

如果 HuiLvService.asmx 提供的是 RESTful 风格的 Web API,您可以使用 HttpClient 类来进行 HTTP 请求。这种方法适用于 Web API 返回的数据是 JSON 或其他常见格式的情况。

示例代码

cs 复制代码
using System;
using System.Net.Http;
using System.Text.Json;
using System.Threading.Tasks;

class Program
{
    static async Task Main()
    {
        using var client = new HttpClient();

        // 设置基础地址
        client.BaseAddress = new Uri("https://your-remote-server-url/");

        // 构造请求数据
        var requestData = new YourRequestData { /*...*/ };

        // 将请求数据序列化为 JSON
        var requestDataJson = JsonSerializer.Serialize(requestData);

        // 构造 HTTP 请求
        var content = new StringContent(requestDataJson, System.Text.Encoding.UTF8, "application/json");

        // 发起 POST 请求
        var response = await client.PostAsync("HuiLvService.asmx/YourRemoteMethod", content);

        // 处理响应
        if (response.IsSuccessStatusCode)
        {
            var responseContent = await response.Content.ReadAsStringAsync();
            // 将响应内容反序列化为结果类型
            var result = JsonSerializer.Deserialize<YourResultType>(responseContent);
            // 处理返回的结果
            Console.WriteLine(result);
        }
        else
        {
            Console.WriteLine("HTTP 请求失败:" + response.StatusCode);
        }
    }
}

请注意,以上代码中的 YourServiceReferenceYourRemoteMethodAsyncYourRequestDataYourResultType 等都是示例,请根据实际情况替换为您的实际服务引用和方法名称。另外,HTTP 客户端方法适用于 RESTful 风格的 Web API,如果服务提供的是 SOAP Web 服务,请使用 Service References 方法来调用。

相关推荐
Rooting++5 分钟前
腾讯无界微前端源码分析
前端
踏着七彩祥云的小丑19 分钟前
云服务器——MySQL设置
服务器·mysql
小嘿前端仔28 分钟前
用AI读源码这件事:前端视角的实战方法论,附Vue3 reactivity源码解读示范
前端
其实防守也摸鱼32 分钟前
XSS漏洞全景解析:从原理、实战利用到纵深防御
前端·网络·安全·xss·xss漏洞
戴维南32 分钟前
DeepAgents 快速上手教程
前端
kaikaile199537 分钟前
C# 文件编码转换工具
开发语言·c#
bigfatDone1 小时前
OpenSpec + Superpowers 联合开发工作流
前端
北漂大橙子1 小时前
OpenSpec 完全指南:让 AI 编码可预测的规范框架
前端
路由侠内网穿透.1 小时前
本地部署开源客服系统 FreeScout 并实现外部访问( Windows 版本)
运维·服务器·网络·windows·网络协议