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

【前端高频面试题】 - TypeScript 篇

【前端高频面试题】 - TypeScript 篇 1. 请解释 TypeScript 是什么?它与 JavaScript 的核心区别是什么? 面试回答需突出 TS 的核心价值(类型安全)和与 JS 的关键差异,结构清晰: * TypeScript 定义:TS 是 JavaScript 的超集(Superset),在 JS 语法基础上增加了静态类型系统,最终会编译为纯 JS 运行(支持所有 JS 环境),核心目标是提升代码可维护性、减少运行时错误。 * 与 JavaScript 的核心区别(分点对比): 1. 类型系统:TS 有静态类型(编译阶段检查类型,变量声明时需指定/推断类型);JS 是动态类型(

Clawdbot Web Chat平台部署避坑指南:Qwen3:32B代理直连常见问题解析

Clawdbot Web Chat平台部署避坑指南:Qwen3:32B代理直连常见问题解析 1. 为什么需要这份避坑指南 你是不是也遇到过这样的情况:明明照着文档一步步操作,Clawdbot界面能打开,聊天框也能输入文字,可按下回车后——光标一直转圈,半天没反应,最后弹出“连接超时”或“API调用失败”?或者更糟,页面直接白屏、控制台报一堆502 Bad Gateway、ERR_CONNECTION_REFUSED? 这不是你的环境有问题,也不是Qwen3:32B模型本身不给力。真正卡住大多数人的,是Clawdbot与本地Ollama服务之间那层看似简单、实则脆弱的代理链路:从浏览器 → Clawdbot前端 → 内部反向代理(8080端口)→ Ollama网关(18789端口)→ Qwen3:32B模型。 这份指南不讲“如何安装Ollama”,也不重复官方启动命令。它只聚焦一件事:把你在真实部署中踩过的、查日志才定位到的、搜遍论坛都找不到答案的典型断点,一条条拎出来,配上可验证的检查项和一招见效的修复方法。全文基于实际生产环境反复验证,

轻松实现Office在线编辑:基于Collabora的Web集成指南

引言 在Web项目中嵌入Office文档编辑功能可以显著提升用户体验。Collabora Online基于LibreOffice核心,提供开源解决方案,支持主流格式(DOCX/XLSX/PPTX等)的实时协作编辑。以下指南详细介绍了如何部署和集成Collabora,实现媲美Office 365的网页端编辑体验。 核心组件与原理 Collabora Online Development Edition (CODE) 服务端提供文档渲染与协作引擎(通过Docker部署),前端通过<iframe>嵌入编辑窗口。 WOPI协议 定义Web应用与Office服务间的通信标准,关键操作包括文件加载、保存回调和权限控制。 部署Collabora服务端 环境要求 Linux服务器(Ubuntu/CentOS)、Docker。 步骤 拉取Collabora镜像: docker pull collabora/code 启动容器: docker run -t -d -p 9980:9980

【前端|2 ES6 + 核心语法全解析】

ES6 + 核心语法全解析(极简可运行代码 + 避坑 + 快速回顾) 前言 学 ES6 语法时总记混let/const作用域、箭头函数this指向、解构赋值传参规则,还踩过 “const 定义对象改属性报错”“模板字符串换行空格” 的坑,整理了 10 个高频核心语法的「问题 + 思路 + 极简例子」,每个例子都能直接复制运行,方便自己后续快速唤醒记忆,也能让新手看懂核心用法。 一、核心思路 / 概念 ES6(ECMAScript 2015)及后续版本是 JavaScript 的重大升级,核心是解决旧语法痛点 + 简化代码:比如用let/const解决var的全局 / 函数作用域混乱问题,用箭头函数简化回调写法并固定this指向,用解构 / 扩展运算符快速操作数组 / 对象,用Promise/Async-Await解决回调地狱。所有语法都围绕 “写更少的代码,做更多的事”,且完全兼容日常开发(