ASP.NET - Web 服务
Web 服务是一种基于 Web 的功能,使用 Web 应用程序使用的 Web 协议进行访问。 Web服务开发包括三个方面:
- 创建 Web 服务
- 创建代理
- 使用 Web 服务
创建 Web 服务
Web 服务是一个 Web 应用程序,它基本上是一个由其他应用程序可以使用的方法组成的类。 尽管它没有用户界面,但它也遵循代码隐藏架构,例如 ASP.NET 网页。
为了理解这个概念,让我们创建一个 Web 服务来提供股票价格信息。 客户可以根据股票代码查询股票的名称和价格。 为了使这个示例简单,这些值被硬编码在二维数组中。 该 Web 服务具有三种方法:
- 默认的 HelloWorld 方法
- GetName 方法
- GetPrice 方法
按照以下步骤创建 Web 服务:
步骤 (1) : 在 Visual Studio 中选择 File -> New -> Web Site,然后选择 ASP.NET Web 服务。
步骤 (2) : 在项目的 App_Code 目录中创建一个名为 Service.asmx 的 Web 服务文件及其代码隐藏文件 Service.cs。
步骤 (3) : 将文件名更改为 StockService.asmx 和 StockService.cs。
步骤 (4) : .asmx 文件上只有一个 WebService 指令:
<%@ WebService Language="C#" CodeBehind="~/App_Code/StockService.cs" Class="StockService" %>
步骤 (5) : 打开StockService.cs文件,里面生成的代码就是基本的Hello World服务。 文件背后的默认 Web 服务代码如下所示:
using System; using System.Collections; using System.ComponentModel; using System.Data; using System.Linq; using System.Web; using System.Web.Services; using System.Web.Services.Protocols; using System.Xml.Linq; namespace StockService { // <summary> // Summary description for Service1 // <summary> [WebService(Namespace = "http://tempuri.org/")] [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)] [ToolboxItem(false)] // 要允许从脚本调用此 Web 服务, // 使用 ASP.NET AJAX,取消注释以下行。 // [System.Web.Script.Services.ScriptService] public class Service1 : System.Web.Services.WebService { [WebMethod] public string HelloWorld() { return "Hello World"; } } }
步骤 (6) : 更改文件后面的代码以添加股票代码、名称和价格的二维字符串数组以及用于获取股票信息的两个 Web 方法。
using System; using System.Linq; using System.Web; using System.Web.Services; using System.Web.Services.Protocols; using System.Xml.Linq; [WebService(Namespace = "http://tempuri.org/")] [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)] // 要允许从脚本调用此 Web 服务, // 使用 ASP.NET AJAX,取消注释以下行。 // [System.Web.Script.Services.ScriptService] public class StockService : System.Web.Services.WebService { public StockService () { //Uncomment the following if using designed components //InitializeComponent(); } string[,] stocks = { {"RELIND", "Reliance Industries", "1060.15"}, {"ICICI", "ICICI Bank", "911.55"}, {"JSW", "JSW Steel", "1201.25"}, {"WIPRO", "Wipro Limited", "1194.65"}, {"SATYAM", "Satyam Computers", "91.10"} }; [WebMethod] public string HelloWorld() { return "Hello World"; } [WebMethod] public double GetPrice(string symbol) { //it takes the symbol as parameter and returns price for (int i = 0; i < stocks.GetLength(0); i++) { if (String.Compare(symbol, stocks[i, 0], true) == 0) return Convert.ToDouble(stocks[i, 2]); } return 0; } [WebMethod] public string GetName(string symbol) { // It takes the symbol as parameter and // returns name of the stock for (int i = 0; i < stocks.GetLength(0); i++) { if (String.Compare(symbol, stocks[i, 0], true) == 0) return stocks[i, 1]; } return "Stock Not Found"; } }
步骤 (7) : 运行 Web 服务应用程序会提供一个 Web 服务测试页面,该页面允许测试服务方法。
步骤 (8) : 单击方法名称,检查其是否正常运行。
步骤 (9) : 为了测试 GetName 方法,请提供股票代码之一,该代码是硬编码的,它返回股票的名称
使用 Web 服务
要使用 Web 服务,请在同一解决方案下创建一个网站。 这可以通过右键单击解决方案资源管理器中的解决方案名称来完成。 调用Web服务的网页应该有一个标签控件来显示返回的结果和两个按钮控件,一个用于回发,另一个用于调用服务。
Web 应用程序的内容文件如下:
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="wsclient._Default" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" > <head runat="server"> <title> Untitled Page </title> </head> <body> <form id="form1" runat="server"> <div> <h3>Using the Stock Service</h3> <br /> <br /> <asp:Label ID="lblmessage" runat="server"></asp:Label> <br /> <br /> <asp:Button ID="btnpostback" runat="server" onclick="Button1_Click" Text="Post Back" style="width:132px" /> <asp:Button ID="btnservice" runat="server" onclick="btnservice_Click" Text="Get Stock" style="width:99px" /> </div> </form> </body> </html>
Web 应用程序的隐藏文件代码如下:
using System; using System.Collections; using System.Configuration; using System.Data; using System.Linq; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.HtmlControls; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using System.Xml.Linq; //this is the proxy using localhost; namespace wsclient { public partial class _Default : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { lblmessage.Text = "First Loading Time: " + DateTime.Now.ToLongTimeString } else { lblmessage.Text = "PostBack at: " + DateTime.Now.ToLongTimeString(); } } protected void btnservice_Click(object sender, EventArgs e) { StockService proxy = new StockService(); lblmessage.Text = String.Format("Current SATYAM Price:{0}", proxy.GetPrice("SATYAM").ToString()); } } }
创建代理
代理是 Web 服务代码的替代。 在使用Web服务之前,必须创建代理。 代理已向客户端应用程序注册。 然后,客户端应用程序像使用本地方法一样调用 Web 服务。
代理接受调用,以正确的格式包装它,并将其作为 SOAP 请求发送到服务器。 SOAP 代表简单对象访问协议。 该协议用于交换Web服务数据。
当服务器将 SOAP 包返回给客户端时,代理会解码所有内容并将其呈现给客户端应用程序。
在使用 btnservice_Click 调用 Web 服务之前,应将 Web 引用添加到应用程序中。 这会透明地创建一个代理类,供 btnservice_Click 事件使用。
protected void btnservice_Click(object sender, EventArgs e) { StockService proxy = new StockService(); lblmessage.Text = String.Format("Current SATYAM Price: {0}", proxy.GetPrice("SATYAM").ToString()); }
执行以下步骤来创建代理:
步骤 (1) : 右键单击解决方案资源管理器中的 Web 应用程序条目,然后单击"添加 Web 引用"。
步骤 (2) : 选择"此解决方案中的 Web 服务"。 它返回 StockService 引用。
步骤 (3) : 单击该服务将打开测试网页。 默认情况下创建的代理名为"localhost",您可以重命名它。 单击"添加引用"将代理添加到客户端应用程序。
通过添加以下内容将代理包含在代码隐藏文件中:
using localhost;