基于 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

GLM-4.6V-Flash-WEB Web界面使用指南,拖图就出结果

GLM-4.6V-Flash-WEB Web界面使用指南,拖图就出结果 你不需要配置环境、不用写一行推理代码、甚至不用打开终端——只要把一张截图拖进浏览器窗口,几秒钟后,它就能告诉你图里写了什么、画了什么、哪里有问题。这不是未来预告,而是你现在就能在本地跑起来的真实体验。 GLM-4.6V-Flash-WEB 是智谱AI最新开源的轻量级视觉语言模型,专为Web端实时交互而生。它不像某些“实验室模型”那样只存在于论文和Benchmark表格里,而是真正做到了:部署快、启动快、响应快、上手更快。一块RTX 3090,一个浏览器,一次拖拽,结果即刻呈现。 本文不讲训练原理,不列参数表格,不堆技术术语。我们只聚焦一件事:怎么用好它的Web界面?从零开始,到稳定产出,每一步都清晰可操作。 1. 为什么说“拖图就出结果”不是宣传话术? 很多多模态模型标榜“支持图文理解”,但实际用起来才发现:要装依赖、改路径、调精度、修CUDA版本、

前端防范 XSS(跨站脚本攻击)

目录 一、防范措施 1.layui util  核心转义的特殊字符 示例 2.js-xss.js库 安装 1. Node.js 环境(npm/yarn) 2. 浏览器环境 核心 API 基础使用 1. 基础过滤(默认规则) 2. 自定义过滤规则 (1)允许特定标签 (2)允许特定属性 (3)自定义标签处理 (4)自定义属性处理 (5)转义特定字符 常见场景示例 1. 过滤用户输入的评论内容 2. 允许特定富文本标签(如富文本编辑器内容) 注意事项 更多配置 XSS(跨站脚本攻击)是一种常见的网络攻击手段,它允许攻击者将恶意脚本注入到其他用户的浏览器中。

详细教程:如何从前端查看调用接口、传参及返回结果(附带图片案例)

详细教程:如何从前端查看调用接口、传参及返回结果(附带图片案例)

目录 1. 打开浏览器开发者工具 2. 使用 Network 面板 3. 查看具体的API请求 a. Headers b. Payload c. Response d. Preview e. Timing 4. 实际操作步骤 5. 常见问题及解决方法 a. 无法看到API请求 b. 请求失败 c. 跨域问题(CORS) 作为一名后端工程师,理解前端如何调用接口、传递参数以及接收返回值是非常重要的。下面将详细介绍如何通过浏览器开发者工具(F12)查看和分析这些信息,并附带图片案例帮助你更好地理解。 1. 打开浏览器开发者工具 按下 F12 或右键点击页面选择“检查”可以打开浏览器的开发者工具。常用的浏览器如Chrome、Firefox等都内置了开发者工具。下面是我选择我的一篇文章,打开开发者工具进行演示。 2. 使用

Cursor+Codex隐藏技巧:用截图秒修前端Bug的保姆级教程(React/Chakra UI案例)

Cursor+Codex隐藏技巧:用截图秒修前端Bug的保姆级教程(React/Chakra UI案例) 前端开发中最令人头疼的莫过于那些难以定位的UI问题——元素错位、样式冲突、响应式失效...传统调试方式往往需要反复修改代码、刷新页面、检查元素。现在,通过Cursor编辑器集成的Codex功能,你可以直接用截图交互快速定位和修复这些问题。本文将带你从零开始,掌握这套革命性的调试工作流。 1. 环境准备与基础配置 在开始之前,确保你已经具备以下环境: * Cursor编辑器最新版(v2.5+) * Node.js 18.x及以上版本 * React 18项目(本文以Chakra UI 2.x为例) 首先在Cursor中安装Codex插件: 1. 点击左侧扩展图标 2. 搜索"Codex"并安装 3. 登录你的OpenAI账户(需要ChatGPT Plus订阅) 关键配置项: // 在项目根目录创建.