JSON是开发的基于文本的数据交换格式. (欲了解关于JSON更多的信息, 请参考在IETF Web site上的 RFC 4627, "The application/json Media Type for JavaScript Object Notation" .) 就像XML一样, JSON具有可阅读和平台无关的特性. JSON格式的数据是轻量级的,并且能很容易被JavaScript解析,这使它成为了ASP.NET AJAX Web applications理想的数据交换格式. 因为它是一种基础的数据格式, JSON 不局限于 ASP.NET AJAX Web applications; 它事实上可以被用于任何需要传递和存储结构化信息为文本的情况. 本文演示了使用JSON从ASP.NET AJAX Web service获取数据.
本文中使用的代理通过BrowserHttpWebRequest 发送信息 ,然后通过HttpWebResponse 接收响应. 代理的使用忽略了Silverlight处理通信的细节. 代理会执行所有的调用.
注意
BrowserHttpWebRequest 不支持跨域. BrowserHttpWebRequest 只有基于silverlight的程序和asp.net ajax 服务部署在同一服务器上才行.
Run View 使用silverlight程序通过JSON格式调用服务的步骤:
创建一个asp.net ajax web 服务.
创建一个Silverlight项目.
创建一个代理来与刚才创建的服务进行通信.
加入托管代码来使用代理接收和传输数据.
Prerequisites (available from the Silverlight download site):
Microsoft Silverlight 1.1 Alpha.
Microsoft Visual Studio Code Name "Orcas" Beta 1.
Microsoft Silverlight Tools Alpha for Visual Studio Code Name "Orcas" Beta 1.
点击下面的按钮查看Silverlight程序调用的Web服务.:
Run View 创建一个Web服务
通过这里的方式创建Web服务Walkthrough: Building a Basic XML Web Service Using ASP.NET.
创建一个Silverlight项目
点击这里How to: Create a Silverlight Project 查看创建Silverlight项目介绍
创建代理
使用slwsdl.exe命令行工具生成代理的代码.
C:\SDtree\SilverlightW2>slwsdl.exe /silverlightClient "http://webdocs/uepreview/Samples/Silverlight.net.webservice/cs/WebService.asmx"-
-or-
当然如果你使用的是orcas创建的程序的话,那么可以直接使用“添加服务引用”,省掉了使用slwsdl.exe工具创建的代码
通过代理调用Web服务
如果你使用的slwsdl工具来创建代理的话,需要将生成的代理类加入到程序中。当然如果你使用的ide工具直接加入的web引用,那么这步就可以省略
使用代理调用服务.
string symbol = _tickerTextBox.GetAttribute("value"); _stockService = new WebService(); _status.Text = string.Format("Calling {0}\r\n", _stockService.Url); // Include the proxy object as the asyncState parameter in the call. IAsyncResult iar = _stockService.BeginGetQuotes(symbol, new AsyncCallback(OnJsonStockDownload), _stockService); if (!iar.IsCompleted) _status.Text += "Waiting for response from server";
处理响应.
public void OnJsonStockDownload(IAsyncResult iar) { try { // Use the WebService object in AsyncState to obtain the results. StockQuote[] quotes = ((WebService)iar.AsyncState).EndGetQuotes(iar); for (int i = 0; i < quotes.Length; i++) { _result.Text += String.Format("Date {0} Open {1} Closed {2}\r\n", quotes[i].Date, quotes[i].Open, quotes[i].Close); } } catch (Exception ex) { _status.Text = ex.Message; } finally { _requestPending = false; _status.Text = "Done"; } }