一:XML Web services 由两部分组成:XML Web services 入口点和实现 XML Web services 功能的代码。在 ASP.NET 中,.asmx 文件是用作 XML Web services 的可寻址入口点的文本文件。它引用预编译的程序集中的代码、代码隐藏文件或包含于 .asmx 文件本身的代码。 三种方式事例如下:
1.引用预编译的程序集中的代码:
2 {
3 /**////
4 public class DeviceListServiceFacade :WebService, IDeviceListServiceFacade
5 {
6 [WebMethod]
7 public void UpdateDeviceChangeListHead(DeviceChangeListHead deviceChangeListHead)
8 {
9 /**////
10 }
11
12 }
13}
.asmx文件内容:
默认情况下,当使用 ASP.NET Web 服务项目模板创建 XML Web services 时,Visual Studio 使用代码隐藏文件,例如在VS2005中,App_Code下将会出现:Service.cs。具体逻辑在此文件实现即可.
.asmx文件内容:
2 using System;
3 using System.Web;
4 using System.Web.Services;
5 using System.Web.Services.Protocols;
6
7 [WebService(Namespace = "http://tempuri.org/")]
8 [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
9 public class CoreCommonWebService : System.Web.Services.WebService {
10
11 [WebMethod]
12 public bool IsAutoFlow(string userId, string workflowName, string taskId, string stepPolicy)
13 {
14 return Baosight.BPMS.Core.Adapter.WorkflowHelper.IsAutoFlow(userId, workflowName, taskId, stepPolicy);
15 }
16}
可以使用 WebService 属性指定命名空间(默认为“http://tempuri.org”)和 XML Web services 的说明文本。默认情况下,ASP.NET Web 服务项目模板不生成包含该属性的类。用逗号分隔多个属性。如下所示意:
2 Description="Some descriptive text could go here." )]
3public class Service1 : System.Web.Services.WebService
4 {
5 // Implementation code.
6}
三:使用 WebMethod 属性
WebMethod 属性 (Attribute) 提供以下属性 (Property):
BufferResponse :启用对 XML Web services 方法响应的缓冲。当设置为 true(默认设置)时,ASP.NET 在将响应向下发送到客户端之前对整个响应进行缓冲。缓冲非常有效,它通过最小化辅助进程和 IIS 进程之间的通信来帮助提高性能。当设置为 false 时,ASP.NET 以 16KB 的块区缓冲响应。通常,只有在不想将响应的全部内容一次缓冲到内存时,才将该属性 (Property) 设置为 false,除非另外指定,默认值为 true。
CacheDuration :启用对 XML Web services 方法结果的缓存。ASP.NET 将缓存每个唯一参数集的结果。该属性 (Property) 的值指定 ASP.NET 应该对结果进行多少秒的缓存处理。值为零,则禁用对结果进行缓存。除非另外指定,默认值为零。
Description :提供 XML Web services 方法的说明,该说明将显示在服务帮助页上。除非另外指定,默认值为空字符串。
EnableSession :启用 XML Web services 方法的会话状态。一旦启用,XML Web services 就可以从 HttpContext.Current.Session 中直接访问会话状态集合,或者,如果它是从 WebService 基类继承的,则可以使用 WebService.Session 属性来访问会话状态集合。除非另外指定,默认值为 false。
MessageName :使 XML Web services 能够唯一确定使用别名的重载方法。除非另外指定,默认值是方法名称。当指定 MessageName 时,结果 SOAP 消息将反映该名称,而不是实际的方法名称。
TransactionOption :使 XML Web services 方法可以作为事务的根对象参与。虽然可以将 TransactionOption 属性 (Property) 设置为 TransactionOption 枚举的任意值,但 XML Web services 方法仅有两个可能的行为:它不参与事务(Disabled、NotSupported、Supported)或它创建一个新事务(Required、RequiresNew)。除非另外指定,默认值为 TransactionOption.Disabled。