基于 C# .NET Framework 开发实现 WebService服务实例详解——一文学懂WebService服务开发技术及应用

基于 C# .NET Framework 开发实现 WebService服务实例详解——一文学懂WebService服务开发技术及应用

        

目录

1. Web Service 概念介绍

1.1 什么是 Web Service

1.2 SOAP(简单对象访问协议)

1.3 WSDL(Web 服务描述语言)

1.4 应用场景

2. 创建 Web Service 项目

3. 编写 Web Service 代码

3.1 打开 WebService1.asmx.cs

3.2 编写服务方法

3.3 代码解析

4. 测试 Web Service

4.1 运行项目

4.2 测试方法

5. 部署 Web Service

5.1 使用 IIS 部署

5.1.1 安装和配置 IIS

5.1.2 发布项目

5.1.3 配置 IIS

5.2 部署到远程服务器

5.2.1 远程服务器准备

5.2.2 使用 FTP 部署

6. 客户端调用 Web Service

6.1 添加服务引用

6.2 编写调用代码

6.3 运行客户端程序

7. 总结


引言

在 C# .NET Framework 环境下开发 Web Service 是一个常见的企业级开发任务。Web Service 提供了一种跨平台、跨语言的通信机制,使不同系统之间能够互相调用和交互。本文将详细介绍如何在 C# .NET Framework中创建、部署和调用 Web Service,包括相关的概念、应用场景、详细的开发步骤、完整示例以及部署方法。【以下示例基于 .NET Framework4.5实现。】

1. Web Service 概念介绍

1.1 什么是 Web Service

Web Service 是一种基于 HTTP、SOAP、XML 等标准协议的分布式计算模型。它允许不同平台和编程语言的应用程序通过网络进行通信和数据交换。Web Service 的主要特点包括:

  • 平台无关性:Web Service 可以在任何支持 HTTP 和 XML 的平台上运行。
  • 语言独立性:Web Service 可以使用任何编程语言来实现和调用。
  • 标准化协议:使用标准化的协议,如 HTTP、SOAP 和 WSDL,确保了互操作性。
1.2 SOAP(简单对象访问协议)

SOAP 是一种基于 XML 的协议,用于在网络上传输结构化信息。SOAP 消息通常包含以下部分:

  • Envelope:定义消息的开始和结束。
  • Header:包含可选的消息头信息。
  • Body:包含实际的消息内容。
1.3 WSDL(Web 服务描述语言)

WSDL 是一种 XML 格式的描述语言,用于描述 Web Service 的接口、方法、参数和返回值。WSDL 文件通常包含以下部分:

  • Types:定义数据类型。
  • Message:定义消息结构。
  • PortType:定义操作和消息的接口。
  • Binding:定义操作与消息的绑定。
  • Service:定义服务端点和地址。
1.4 应用场景

Web Service 的应用场景包括但不限于:

  • 跨平台系统集成:例如,将 Java 应用程序与 C# 应用程序进行集成。
  • 分布式系统:例如,微服务架构中的服务调用。
  • 企业服务总线(ESB):使用 Web Service 实现业务功能的松耦合。
  • B2B 电子商务:不同企业之间的数据交换和业务流程集成。

2. 创建 Web Service 项目

选择Web服务,点击添加。一个简单的webservice就创建完成了。

经过上面两步,我们就生成了一个空的Web应用程序项目,然后鼠标右键点击项目,选择 添加>新建项。

创建一个空的Web应用程序,选择如下:

打开 Visual Studio打开 Visual Studio,选择 File -> New -> Project 以创建一个新的项目。我们选择ASP.NET  Web应用程序,如下图所示,项目名称和位置可自己修改,然后点确定进入下一步:

 然后Visual Studio 会生成一个默认的 Web Service 项目结构。项目包含以下重要文件:

  • WebService1.asmx:默认的 Web Service 文件,包含服务的入口点。
  • WebService1.asmx.cs:服务的代码文件,定义服务方法。

  

3. 编写 Web Service 代码

在本节中,我们将编写一个简单的计算服务,提供加法和乘法功能。

3.1 打开 WebService1.asmx.cs

在解决方案资源管理器中,找到 WebService1.asmx 文件,右键点击并选择 View Code 打开 WebService1.asmx.cs

3.2 编写服务方法

添加以下代码以定义 AddMultiply 方法:

using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Services; namespace MyWebService { /// <summary> /// WebService1 的摘要说明 /// </summary> [WebService(Namespace = "http://tempuri.org/")] [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)] [System.ComponentModel.ToolboxItem(false)] // 若要允许使用 ASP.NET AJAX 从脚本中调用此 Web 服务,请取消注释以下行。 // [System.Web.Script.Services.ScriptService] public class WebService1 : System.Web.Services.WebService { [WebMethod] public string HelloWorld() { return "Hello World"; } [WebMethod] public int Add(int a, int b) { // 返回两个数的和 return a + b; } [WebMethod] public int Multiply(int a, int b) { // 返回两个数的乘积 return a * b; } } } 
3.3 代码解析
  • [WebService]:表明该类是一个 Web Service。
  • [WebServiceBinding]:定义 Web Service 绑定的配置。
  • [WebMethod]:标记类中的方法,使其可以作为 Web Service 方法被调用。

4. 测试 Web Service

4.1 运行项目

F5 运行项目,Visual Studio 会启动一个开发服务器,并在默认浏览器中打开 http://localhost:XXXXX/webService1.asmxXXXXX 是端口号)。

4.2 测试方法

在浏览器中,可以看到 Web Service 的描述页面,包含了 AddMultiply 方法。点击方法名,可以进入测试页面:

  1. Add 方法:输入参数 a 和 b,点击 Invoke。浏览器会显示返回结果,例如 <int>30</int>
  2. Multiply 方法:输入参数 a 和 b,点击 Invoke。浏览器会显示返回结果,例如 <int>200</int>

5. 部署 Web Service

Web Service 开发完成后,需要将其部署到服务器,使得客户端可以访问。

5.1 使用 IIS 部署
5.1.1 安装和配置 IIS
  1. 打开控制面板,选择 程序和功能,点击 启用或关闭 Windows 功能
  2. 在 Windows 功能对话框中,勾选 Internet Information Services,并确保 ASP.NET 和 IIS 管理控制台 已勾选,点击 确定
5.1.2 发布项目
  1. 在解决方案资源管理器中右键点击项目,选择 Publish
  2. 在发布对话框中选择发布目标,如 File System,指定发布路径(如 C:\inetpub\wwwroot\MyWebService),点击 Publish
5.1.3 配置 IIS
  1. 打开 IIS 管理器,右键点击 Default Web Site,选择 Add Application
  2. 在添加应用程序对话框中输入 Alias(如 MyWebService),选择应用程序池,选择物理路径(发布路径)。
  3. 点击 OK,应用程序会被添加到默认网站下。
  4. 在浏览器中输入 http://localhost/MyWebService/Service1.asmx 检查 Web Service 是否正常工作。
5.2 部署到远程服务器
5.2.1 远程服务器准备
  1. 确保目标服务器已安装 IIS 并配置 ASP.NET
  2. 确保目标服务器防火墙允许 HTTP/HTTPS 访问。
5.2.2 使用 FTP 部署
  1. 在解决方案资源管理器中右键点击项目,选择 Publish
  2. 在发布对话框中选择 FTP,输入远程服务器的 FTP 地址、用户名和密码,指定目标路径(如 /var/www/MyWebService),点击 Publish
  3. 发布完成后,浏览器中输入 http://yourserveraddress/MyWebService/webService1.asmx 检查 Web Service 是否正常工作。

6. 客户端调用 Web Service

6.1 添加服务引用
  1. 打开一个新的或现有的 .NET 项目(如控制台应用),右键点击项目选择 Add Service Reference
  2. 在服务引用对话框中点击 Discover 或输入 Web Service 的 URL(如 http://localhost/MyWebService/webService1.asmx)。
  3. 点击 Go,选择服务并输入命名空间(如 MyWebServiceReference),点击 OK
6.2 编写调用代码

在项目中编写代码调用 Web Service:

using System; namespace MyWebServiceClient { class Program { static void Main(string[] args) { // 创建服务客户端实例 var client = new MyWebServiceReference.Service1SoapClient(); // 调用 Add 方法 int sum = client.Add(10, 20); Console.WriteLine($"10 + 20 = {sum}"); // 调用 Multiply 方法 int product = client.Multiply(10, 20); Console.WriteLine($"10 * 20 = {product}"); // 关闭客户端 client.Close(); } } } 
6.3 运行客户端程序

运行客户端程序,可以看到调用 Web Service 的结果输出到控制台。

7. 总结

        在本文中,我们详细介绍了如何在 C# .NET Framework  环境下开发、测试、部署和调用 Web Service。我们从概念入手,逐步讲解了 Web Service 的开发步骤和代码示例,最终展示了如何通过客户端调用 Web Service。

        通过这种基于标准化协议的分布式服务,开发人员可以实现跨平台、跨语言的互操作,满足企业级应用和系统集成的需求。希望本文能帮助你更好地理解和掌握 Web Service 的开发与应用。

Read more

openclaw飞书机器人权限管理

为了确保 OpenClaw 既能顺畅运行,又不至于因权限过大导致安全隐患,建议在飞书开发者后台 - 权限管理中,按照以下清单进行勾选。 这份清单分为基础必备和进阶功能两部分: 1. 基础必备权限(无论个人还是团队,必须开启) 这些权限保证机器人能“听到”指令并“开口”说话: * im:message:p2p_msg:readonly (接收单聊消息) —— 允许机器人和你 1 对 1 聊天。 * im:message:group_at_msg:readonly (接收群聊中@机器人的消息) —— 团队场景下,机器人只响应被 @ 的内容,保护群隐私。 * im:message.p2p_msg:send (发送单聊消息) —— 机器人回复你的基础。 * im:message.

MIPI DSI 4-Lane液晶屏驱动开发实战:从时序解析到FPGA对接

1. MIPI DSI 4-Lane液晶屏基础认知 第一次接触MIPI DSI 4-Lane液晶屏时,我被它复杂的时序图吓到了——直到把它想象成高速公路的车道管理才豁然开朗。这种显示屏采用串行差分信号传输,4条数据通道就像双向四车道的高速公路,每条lane的传输速率可达480MHz(实测GOWIN开发板环境),比传统并行RGB接口节省了约60%的引脚资源。 以常见的5寸720x1280分辨率屏幕为例,其核心参数如下表: 参数项典型值技术要点接口类型MIPI DSI 4-Lane支持LP/HS双模式分辨率720(H)×1280(V)60Hz刷新率色彩深度24bit RGB实际传输采用RGB888压缩为RGB565功耗特性LP模式<10mAHS模式峰值电流约120mA同步模式SYNC EVENT需要精确控制消隐区时序 在硬件连接时,我曾犯过把CLK和DATA线序接反的低级错误。正确的接线顺序应该是: 1. 先对接CLK+/CLK-差分对(相当于交通信号灯) 2. 再按D0+/D0-到D3+/D3-顺序连接数据线 3. 最后接电源和背光(VCC/VLED等) 2.

Whisper.cpp移植参考:如何在PyTorch镜像中部署语音识别模型

Whisper.cpp移植参考:如何在PyTorch镜像中部署语音识别模型 1. 为什么要在PyTorch镜像里跑Whisper.cpp? 你可能已经注意到一个有趣的现象:Whisper.cpp是用C/C++写的,而PyTorch镜像默认装的是Python生态——这看起来有点“不搭”。但现实中的工程落地,从来不是非此即彼的选择。 真实场景往往是这样的:你的团队刚用PyTorch训练完一个语音增强模型,现在需要把降噪后的音频送进ASR系统做转录;或者你在Jupyter里做语音数据探索分析,顺手想调用本地ASR快速验证一段录音内容;又或者你正开发一个端到端语音处理Pipeline,前端用PyTorch做特征提取,后端需要轻量级、低依赖的推理引擎。 这时候,硬生生拉起一个纯C环境反而增加运维负担。而PyTorch-2.x-Universal-Dev-v1.0镜像恰恰提供了最理想的“中间地带”:它自带CUDA驱动、已配置好清华/阿里源、预装了tqdm和requests等实用工具,更重要的是——它没有预装任何与Whisper.cpp冲突的LLVM或OpenMP版本,编译兼容性极佳。