以文本方式查看主题 - 中文XML论坛 - 专业的XML技术讨论区 (http://bbs.xml.org.cn/index.asp) -- 『 XML在电子商务与电子政务中的应用 』 (http://bbs.xml.org.cn/list.asp?boardid=36) ---- Visual Studio .NET 中的 XML Web services 入门 (http://bbs.xml.org.cn/dispbbs.asp?boardid=36&rootid=&id=5707) |
-- 作者:admin -- 发布时间:3/17/2004 11:04:00 PM -- Visual Studio .NET 中的 XML Web services 入门 Visual Studio .NET 中的 XML Web services 入门 Rob Caron Visual Studio Team Microsoft Corporation 2002 年 2 月 摘要:Microsoft® Visual Studio® .NET 和 XML Web services 提供了一个简单、灵活且基于标准的模型 ,开发人员无论使用何种平台、编程语言或对象模型均可以编写组合应用程序。本文将帮助您快速学习使用 Visual Studio .NET 创建并访问 XML Web services。本文包含一些指向英文站点的链接。 目录 程度上依赖于已经被广泛接受的支持互操作的 XML、HTTP 和其他 Internet 标准。 XML Web services 可以由单个应用程序在内部使用或通过 Internet 对外公开供多个应用程序使用。XML Web services 可通过标准接口进行访问,允许异类的系统以同一种 Web 方式协同工作。 XML Web services 没有追随一般的代码可移植性功能,而是提供了一个使数据和系统能够协同工作的可行 的解决方案。XML Web services 使用基于 XML 的消息在多个使用不同组件模型、操作系统和编程语言的系 统间交换数据。采用与通常在分布式应用程序中使用组件相同的方法,开发人员可以创建应用程序,将不同 来源的 XML Web services 组合在一起。 XML Web services 的一个核心特征是在服务的实施和使用方面的高度抽象。通过将基于 XML 的消息用作创 建和访问服务的机制,XML Web services 客户端和 XML Web services 提供商除了需要了解对方的输入、 输出和位置以外,不再需要任何其他信息。 XML Web services 将分布式应用程序的开发带入了新的时代。使用专有结构的紧耦合系统牺牲了应用程序 的互操作性。XML Web services 将互操作性推到了一个全新的高度。作为新一代 Internet 的革命性进步 ,XML Web services 将成为链接所有计算设备的基础结构。 有关详细信息,请参阅 Programming the Web with XML Web services。 用托管代码编写的 XML Web services 问 .NET 框架的许多功能,如身份验证、缓存和状态管理。这样一来,开发人员便可以专注于创建或访问 XML Web services,而无需编写基础结构代码。 在 ASP.NET 应用程序模型中,Web 页专供使用 .aspx 扩展名的浏览器使用。为了使 XML Web services 和 常规 ASP.NET 页区分开来,XML Web services 使用 .asmx 扩展名。 XML Web services 由 XML Web services 入口点和实现 XML Web services 功能的代码组成。在 ASP.NET 中,.asmx 文件充当 XML Web services 的可寻址入口点。它引用预编译程序集中的代码、文件的支持代码 或 .asmx 文件本身包含的代码。 使用 XML Web services 时,有两种基本的操作: 创建 XML Web services - 创建 XML Web services 时,实际上是在创建一个将功能向 XML Web services 客户端公开的应用程序。 services 中包含的功能。 XML Web services 发送消息。 有关详细信息,请参阅 XML Web services in Managed Code。 使用 Visual Studio 创建 XML Web services 应用程序将在 Web 项目的环境中创建)而配置的 Web 服务器。Web 项目的种类很多,当您要在 Visual Studio .NET 中使用采用托管代码的 XML Web services 时,可以使用 ASP.NET Web Service 项目模板。 在 Visual Studio 中创建 XML Web services 项目后,就会看到 Component Designer(组件设计器)。组 件设计器是 XML Web services 的设计界面。可以使用 Design(设计)视图向 XML Web services 添加组 件,并使用 Code(代码)视图查看或编辑与 XML Web services 关联的代码。 在 Visual Studio 中创建 ASP.NET Web Service 项目后,它将在 Web 服务器上构造一个 Web 应用程序项 目结构,同时在您的本地计算机上构造一个 Visual Studio 解决方案文件。解决方案文件 (.sln) 包含配 置和生成设置,并且保存着一系列与项目关联的文件。此外,Visual Studio 将自动创建支持 XML Web services 所必需的文件和引用。完成后,Visual Studio 集成开发环境 (IDE) 将在 Design(设计)视图 中显示 .asmx 文件。 默认情况下,当您使用 ASP.NET Web Service 项目模板创建 XML Web services 时,Visual Studio 将使 用“支持代码文件”(如 Service1.asmx.vb 或 Service1.asmx.cs)。支持代码文件包含实现 XML Web services 功能的代码。默认情况下,Solution Explorer(解决方案资源管理器)会隐藏支持代码文件。当 查看 .asmx 文件的 Code(代码)视图时,实际上您是在查看支持代码文件的内容。.asmx 文件本身包含处 理指令 WebService,它指示在何处可以找到 XML Web services 的实现方案。生成采用托管代码的 XML Web services 后,ASP.NET 将自动提供基础结构并处理 XML Web services 的请求和响应,包括分析和创 建简单对象访问协议 (SOAP) 消息。编译的输出是一个 .dll 文件,该文件位于项目的 bin 文件夹中。 有关详细信息,请参阅 Creating XML Web services in Managed Code。 WebService 处理指令 .asmx 文件中 WebService 处理指令的示例: ' Visual Basic // C# 文件,然后单击快捷菜单中的 Open With(打开方式)。在 Open With(打开方式)对话框中,选择 Source Code (Text) Editor(源代码 [文本] 编辑器),然后单击 Open(打开)。 Visual Basic .NET 或 Visual C#)来创建 XML Web services。与 .asmx 页关联的支持代码文件由 Codebehind 属性来指示。Class 属性指示支持代码文件中用来实现 XML Web services 功能的类。 有关详细信息,请参阅 Code Model for XML Web services in Managed Code。 System.Web.Services.WebService 类 ASP.NET 对象(如应用程序和会话状态的对象)的权限。默认情况下,使用 Visual Studio 以托管代码的 形式创建的 XML Web services 继承此类。XML Web services 可以继承此类以获得访问 ASP.NET 固有对象 (如 Request 和 Session)的权限。 如果 XML Web services 没有继承此类,也可以从 System.Web.HttpContext.Current 访问 ASP.NET 固有 对象。实现 XML Web services 的类必须是公共的,并且必须有一个公共的默认构造函数(不带参数的构造 函数)。这样,ASP.NET 就能够创建 XML Web services 类的实例以处理传入的 XML Web services 请求。 有关详细信息,请参阅 Inheriting from the WebService Class。 WebService 属性 XML Web services。在 Visual Studio .NET 中创建的 XML Web services 的默认命名空间是“http://tempuri.org/”。尽管命名空间类似于典型的 URL,但在 Web 浏览器中是不能 查看的,它只是一个唯一标识符。 注意:您可能希望在包含有关您所提供的 XML Web services 信息的位置提供一个 Web 页。 Description - 此属性的值包含描述性消息,此消息将在 XML Web services 的说明文件(例如服务说明和 服务帮助页)生成后显示给 XML Web services 的潜在用户。 名称。Name 属性标识 XML Web services 的 XML 限定名称的本地部分。Name 属性也用于在服务帮助页上 显示 XML Web services 的名称。 中创建名称的方法,该名称可由统一资源标识符 (URI) 标识。使用 XML 命名空间,可以唯一标识 XML 文 档中的元素或属性。因而,在 XML Web services 的服务说明中,Namespace 被用作与 XML Web services 直接相关的 XML 元素的默认命名空间。如果不指定命名空间,就使用默认命名空间 http://tempuri.org/ 。 ' Visual Basic // C# WebMethod 属性 XML Web services 中可用的方法。Private 方法不能充当 XML Web services 的入口点,尽管它们可以采 用相同的类并且 XML Web services 代码可以调用它们。WebMethod 属性必须应用到可用作 XML Web services 一部分的每种公共方法中。 WebMethod 属性包含配置 XML Web services 行为的几个属性。例如,可以使用此属性在相关服务帮助页提 供一个简短说明。 WebMethod 属性提供以下属性: BufferResponse - 当设置为 True(默认设置)时,ASP.NET 将响应向下发送到客户端之前先缓存整个响应 。缓存是一种非常有效的方法,可以通过减少辅助进程和 Internet 信息服务 (IIS) 进程之间的通信来提 高性能。当设置为 False 时,ASP.NET 会将响应缓存在 16 KB 的区块中。通常,只有在不想一次将响应的 全部内容都缓存在内存中时,才将此属性设置为 False。例如,正在写回一个将项流出数据库的集合。除非 另行指定,否则默认值为 True。 默认值为 0,此设置将禁用结果缓存。 ,否则默认值为空字符串。 态。当设置为 True 时,XML Web services 可以直接从 HttpContext.Current.Session 访问会话状态集合 ;在继承了 WebService 基类的情况下,也可以使用 WebService.Session 属性进行访问。 则默认值为方法名。当为 MessageName 指定值后,结果 SOAP 消息会反映出此名称而不是实际的方法名。 TransactionOption 属性设置为 TransactionOption 枚举类型的任意值,但是 XML Web services 方法仅 有两种可能行为:它不参与事务(Disabled、NotSupported 和 Supported),或是创建新事务(Required 和 RequiresNew)。除非另行指定,否则默认值为 TransactionOption.Disabled。要使用此属性,需要向 System.EnterpriseServices.dll 添加一个引用。此命名空间包含的方法和属性,提供了可在 COM+ 服务中 找到的分布式事务模型。System.EnterpriseServices.ContextUtil 类允许您使用 SetAbort 或 SetComplete 方法设置该事务。 ' Visual Basic // C# 使用 Visual Studio 部署 XML Web services 目,然后将结果文件部署到生产服务器。项目 .dll 文件包含 XML Web services 代码类文件(.asmx.vb 或 .asmx.cs)以及项目中的所有其他类文件,但不包含 .asmx 文件本身。然后,您可以将这一个项目 .dll 文件部署到生产服务器中,而无需附带任何源代码。当 XML Web services 接收到请求时,项目 .dll 文件将被加载并执行。 图 1:部署 XML Web services 要将 XML Web services 部署到非开发服务器,可以添加 Web 安装项目,也可以将所需的文件复制到目标 服务器。要使您的 XML Web services 可供其他人使用,需要将其部署到可供目标客户端访问的 Web 服务 器。 有关详细信息,请参阅 Deploying XML Web services in Managed Code。 服务帮助页 回一个自动生成的服务帮助页。 例如,要访问名为 Service1.asmx(本地计算机中 WebService1 项目的一部分)的 XML Web services 的 服务帮助页,可使用以下 URL: http://localhost/WebService1/Service1.asmx 个指向其详细信息的链接。另外,此帮助页还包括指向 XML Web services 说明文档的链接。 图 2:服务帮助页 服务帮助页的文件名在配置文件的 <wsdlHelpGenerator> XML 元素(默认设置为 DefaultWsdlHelpGenerator.aspx)中指定。默认情况下,此特定 ASP.NET Web 窗体是该计算机中所有 XML Web services 所通用的: \%WINDOWS% )。另外,也可以修改相关 Web .config 文件的 <wsdlHelpGenerator> 元素以指定自定义服务帮助页。 有关详细信息,请参阅 Configuration Options for XML Web services Created Using ASP.NET。 服务方法帮助页 协议的方法。但是,随后却无法调用要求复杂输入参数(如 DataSet)类型的方法。另外,XML Web services 方法必须支持 HTTP-POST 协议才能启用此功能。在服务方法帮助页的底部还提供了协议(XML Web services 方法所支持的)的请求和响应消息示例。 图 3:服务方法帮助页 例如,要访问 Service1.asmx(本地计算机中 WebService1 项目的一部分)中名为 MyWebMethod 的 XML Web services 方法,可使用以下 URL: http://localhost/WebService1/Service1.asmx?op=MyWebMethod Web Service 说明 (.wsdl) 定义。服务说明是使用 Web Service 说明语言 (WSDL) 语法的文档。服务说明定义了与 XML Web services 交换信息时,客户端需要遵循的消息格式合约。 Web Service 说明示例 <?xml version="1.0" encoding="utf-8"?> 明(如上例所示),可使用以下 URL: http://localhost/TempConvert2/Service1.asmx?WSDL XML Web services 发现 的基本步骤。通过发现进程,XML Web services 客户端能够在设计阶段了解某个 XML Web services 是否 存在,它的功能如何,以及如何正确与它进行交互操作。 然而,实现 XML Web services 的 Web 站点不需要支持该发现进程,而是由另一个站点负责说明服务(如 XML Web services 目录)。另外,可能没有一个公开的方法可用来查找服务,例如在创建专用服务时。 有关详细信息,请参阅 XML Web services Discovery。 静态发现 (.disco) 用 XML Web services 的程序发现。使用 ASP.NET 自动创建的 XML Web services 能够提供生成的发现文 档。例如,要访问名为 Service1.asmx(本地计算机中 WebService1 项目的一部分)的 XML Web services 发现文档,可使用以下 URL: http://localhost/WebService1/Service1.asmx?DISCO <?xml version="1.0" ?> 是相对的,则假定它们是相对于发现文档的位置。 动态发现 (.vsdisco) services 的过程。动态发现 (.vsdisco) 文件是基于 XML 的文件,可以包含零或多个 <exclude> 节点。 每个 <exclude> 节点包含一个“path”属性,path 属性包含指向子文件夹(动态发现进程不应搜索的子文 件夹)的相对路径。以下是 .vsdisco 示例文件: <?xml version="1.0" encoding="utf-8" ?> Service,都会返回一个包含 Web Service 发现信息的发现文档。 默认情况下,web.config 中禁用了动态发现。要积极控制哪些 XML Web services 客户端可以发现服务, 应该在开发 Web 服务器上只使用动态发现。当向生产 Web 服务器部署 XML Web services 时,应为那些希 望客户端能够发现的 XML Web services 创建并发布一个静态发现文件 (.disco)。 有关详细信息,请参阅 Deploying XML Web services in Managed Code。 Web Service 目录 services 可以为多数人使用的一种既定方法是,将其注册到 XML Web services 目录中。通用说明、发现 和集成 (UDDI) 项目提供了一份公司及其提供的服务的目录。 有关详细信息,请参阅 XML Web services Directories。 使用 Visual Studio 访问 XML Web services 端的应用程序,事实上,在大多数情况下,您的 XML Web services 客户端可能是其他 Web 应用程序(如 Web 窗体或其他 XML Web services)。当访问采用托管代码的 XML Web services 时,代理类和 .NET 框 架将处理所有结构代码。 从托管代码访问 XML Web services 是一个简单的过程。首先,向希望访问的 XML Web services 项目添加 一个 Web 引用。Web 引用使用作为代理的方法为每个公开的 XML Web services 方法创建代理类。其次, 添加 Web 引用的命名空间。最后,创建代理类实例并像访问其他类的方法一样访问该类方法。 有关详细信息,请参阅 Accessing XML Web services in Managed Code。 查找 XML Web services 并添加 Web 引用 能知道 XML Web services 的位置和功能。但在其他时候,您可能是访问由别人提供的 XML Web services 。在这种情况下,您或许不知道 XML Web services 是否满足您的要求。 为了简化代码模型,用托管代码编写的应用程序使用一个 Web 引用来代表各本地 XML Web services。通过 使用 Add Web Reference(添加 Web 引用)对话框向您的项目添加 Web 引用。此对话框使您可以浏览您的 本地服务器、Microsoft UDDI 目录和 Internet 上的 XML Web services。 Add Web Reference(添加 Web 引用)对话框使用 XML Web services 发现进程,在从对话框中浏览的 Web 站点上,查找合适的 XML Web services。对于给定的地址,它使用为查找 XML Web services 发现 (DISCO) 文档并最终找到 XML Web 说明文档(遵守 Web Service 说明语言 [WSDL] 的语法)而设计的算法 来询问 Web 站点。 当使用 Add Web Reference(添加 Web 引用)对话框查找到应用程序访问的 XML Web services 后,单击 Add Reference(添加引用)按钮告诉 Visual Studio 将服务说明的一份副本下载到本地计算机,然后生成 访问所选 XML Web services 的代理类。代理类包含了一些方法,可以同步或异步调用公开的 XML Web services 方法。 有关详细信息,请参阅 Locating XML Web services。 动态和静态 URL XML Web services 的 URL。默认情况下,此属性被设置为所选 XML Web services 的 URL(是一个静态 URL)。 如果将 URL Behavior 属性设置保留为默认值 Static,则当创建类实例时,会使用硬编码的 URL 来设置该 代理类的 URL 属性。 如果将 Web 引用的 URL Behavior 属性设置为 Dynamic,则应用程序在运行时将从您的应用程序配置文件 的 <appSettings> 部分获得 URL,例如: <appSettings> URL,它必须是符合 WSDL 的 XML Web services;当添加 Web 引用时,应与已使用的 XML Web services 相匹配。否则,早期生成的代理类将不能与之交互。 添加 Web 引用时,您也可以使用 Visual Studio 所使用的同一工具(XML Web services 说明语言工具) 生成代理类来创建代理类。当您不能从安装 Visual Studio 的计算机上访问 XML Web services 时,该方 法是很有用的。例如,当 XML Web services 所在的网络直到运行时仍不能被客户端访问时。然后,您要手 动向应用程序项目添加工具生成的文件。 有关详细信息,请参阅 Managing Project Web References。 使用代理类 类来说,在调用方法之前,您必须首先创建它的实例。此过程与创建其他类实例没有区别。 当使用 Visual Studio 直接从 XML Web services 的服务说明中生成的代理类时,访问采用托管代码的 XML Web services 比较简单。要访问 XML Web services 方法,您的客户端应用程序应调用相应的代理对 象同步方法或异步方法。这些方法执行必要的工作,来远程调用需要的 XML Web services 方法。默认情况 下,代理类使用 SOAP 来访问 XML Web services 方法,因为 SOAP 对三种支持的协议操作(HTTP-GET、HTTP-POST 和 HTTP-SOAP)支持最丰富的数据类型。 通过 Add Web Reference(添加 Web 引用)进程生成的代理类来自 System.Web.Service.Protocols.SoapHttpClientProtocol 类,它包含的几个属性可用来控制该类访问 XML Web services 的行为。 除此以外,SoapHttpClientProtocol 类还提供了以下属性: ClientCertificates - 此属性允许客户端在调用 XML Web services 方法时传递一个或多个客户端证书( 也叫做 Authenticode X.509 v.3 证书)。 services 客户端(用来唯一标识 XML Web services 客户端的会话)传回一个 cookie。对于收到该 cookie 的 XML Web services 客户端,必须创建一个 CookieContainer 的新实例并在调用 XML Web services 方法之前将其属性指定为 CookieContainer。这就可以确保 cookie 能够正确地包含在后续请求 中。 类(如 NetworkCredential),然后设置专用于验证机制的客户凭证。NetworkCredential 类可以用来设置 使用基本、摘要式、NTLM 和 Kerberos 身份验证机制的验证凭证。 个请求发送。当 PreAuthenticate 为 False(默认值)时,无需先进行用户身份验证,就可以向 XML Web services 方法发送请求。如果知道 Web Service 需要验证,就可以通过将属性设置为 True 来节省一次往 返操作。 WebProxy 类来设置代理设置,因为它可以实现 IWebProxy。否则,默认代理设置可能将在配置文件中进行 设置。 置为 Timeout.Infinite,表示请求没有超时。但是,Web 服务器仍然有可能引起请求在服务器端超时。 调用 XML Web services 方法 法一样来访问结果。 在以下的示例代码中,客户端应用程序 (Application1) 访问一个具有 Web 引用 (Converter) 的 XML Web services,该 Web 引用包含代理类 Service1,而代理类又有一个调用 XML Web services 的方法 ConvertTemperature。代码中的粗体行是访问 XML Web services 所必需的。 ' Visual Basic // C# 总结 息可以是结构化的、带类型的,也可以是松散定义的。由于 XML Web services 的基础是标准协议,因此您 的 XML Web services 应用程序能够与很多实现、平台和设备进行通信。 可以使用 ASP.NET 页框架创建 XML Web services,并使这些 XML Web services 能够访问 .NET 框架的许 多功能。由于 ASP.NET 和 .NET 框架是采用托管代码的 XML Web services 的基础,开发人员可以专注于 创建或访问 XML Web services,而不需要编写基础结构代码。 当您使用 Visual Studio 直接从 XML Web services 的服务说明中生成的代理类时,访问采用托管代码的 XML Web services 比较简单。代理类代码将方法调用转换为请求消息,并将响应信息返回给方法的返回值 。 有关在 Visual Studio .NET 中创建和访问 XML Web services 的详细步骤说明,请参阅 Creating and Accessing XML Web services Walkthroughs 和 Support WebCast:Microsoft .NET: Introduction to Web Services (http://support.microsoft.com/default.aspx?scid=http://support.microsoft.com/servicedesks/webc asts/wc012902/wcblurb012902.asp)。
|
-- 作者:feelwto -- 发布时间:6/9/2005 10:05:00 PM -- 坐下慢慢看 |
-- 作者:d_hao20@ustc.edu -- 发布时间:9/1/2005 10:06:00 PM -- 好文章,内容觉得还不够,我喜欢。有没有pdf版的。 |
-- 作者:yibingzheng -- 发布时间:9/29/2005 8:18:00 AM -- 不错! |
-- 作者:abdemen_2 -- 发布时间:1/19/2006 10:35:00 PM -- 生活就像被xx,不如闭上眼去享受 |
W 3 C h i n a ( since 2003 ) 旗 下 站 点 苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》 |
140.625ms |