silverlight动态读取txt文件/解析json数据/调用wcf示例

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
简介: 终于开始正式学习silverlight,虽然有点晚,但总算开始了,今天看了一下sdk,主要是想看下silverlight中如何动态调用数据,对于数据库的访问,sdk中的官方示例多用的是Ado.Net数据服务,方便到是方便,就是感觉Ado.

终于开始正式学习silverlight,虽然有点晚,但总算开始了,今天看了一下sdk,主要是想看下silverlight中如何动态调用数据,对于数据库的访问,sdk中的官方示例多用的是Ado.Net数据服务,方便到是方便,就是感觉Ado.Net数据服务返回的xml太啰嗦了,一点也不精简,数据通讯量太大(N多无用的标签导致客户端与服务端之间传输数据增加了不少),于是想到能否直接用wcf返回json格式,

何况sdk中提到silverlight中System.Json已经完成了对json的解析


经实验,用WebClient貌似就能解析一切,包括加载json文本,纯文本,以及wcf,不过要注意的是:xap与被调用的txt或wcf必须在同一个域下,否则将调用失败,具体看下面的代码

Page.Xaml完整内容如下:

 

 1 < UserControl  x:Class ="WcfTest.Page"
 2     xmlns ="http://schemas.microsoft.com/winfx/2006/xaml/presentation"  
 3     xmlns:x ="http://schemas.microsoft.com/winfx/2006/xaml"  
 4      >
 5      < Grid  x:Name ="LayoutRoot"  Background ="White"  ShowGridLines ="True" >
 6          < Grid.RowDefinitions >
 7              < RowDefinition  Height ="*" ></ RowDefinition >
 8              < RowDefinition  Height ="*" ></ RowDefinition >
 9              < RowDefinition  Height ="*" ></ RowDefinition >
10          </ Grid.RowDefinitions >
11         
12          < TextBlock  x:Name ="txtJson"  Grid.Row ="0"  Grid.Column ="0" ></ TextBlock >
13          < TextBlock  x:Name ="txtBlank"  Grid.Row ="1"  Grid.Column ="0"   TextWrapping ="Wrap" ></ TextBlock >
14          < TextBlock  x:Name ="txtWcf"  Grid.Row ="2"  Grid.Column ="0"   TextWrapping ="Wrap" ></ TextBlock >
15         
16      </ Grid >
17 </ UserControl >

 

Page.Xaml.cs完整内容如下:

ContractedBlock.gif ExpandedBlockStart.gif Code
using System;
using System.Json;
using System.Net;
using System.Windows.Controls;
using System.IO;

namespace WcfTest
{
    
public partial class Page : UserControl
    {
        
public Page()
        {
            InitializeComponent();
            LoadJsonTxt();
            LoadBlankTxt();
            LoadWcfTxt();
        }

        
/// <summary>
        
/// 加载Json格式的文本文件
        
/// </summary>
        void LoadJsonTxt()
        {
            Uri serviceUri 
= new Uri("http://localhost:7055/data/json.txt");//很奇怪,只能用绝对路径
            WebClient downloader = new WebClient();
            downloader.OpenReadCompleted 
+= new OpenReadCompletedEventHandler(LoadJsonTxtCompleted);
            downloader.OpenReadAsync(serviceUri);
        }

        
/// <summary>
        
/// 异常回调函数
        
/// </summary>
        
/// <param name="sender"></param>
        
/// <param name="e"></param>
        void LoadJsonTxtCompleted(object sender, OpenReadCompletedEventArgs e)
        {
            
if (e.Error == null)
            {
                JsonArray _data 
= (JsonArray)JsonArray.Load(e.Result);
                
string _Result = "";
                
for (int i = 0; i < _data.Count; i++)
                {
                    _Result 
+= (",name=" + _data[i]["name"].ToString());
                }
                
if (_Result.StartsWith(""))
                {
                    _Result 
= _Result.Substring(1);
                }
                
this.txtJson.Text = _Result;
            }
            
else
            {
                txtJson.Text 
= "出错:" + e.Error.Message.ToString();
            }
        }


        
/// <summary>
        
/// 加载普通格式的文本文件
        
/// </summary>
        void LoadBlankTxt()
        {
            Uri serviceUri 
= new Uri("http://localhost:7055/data/txt.txt");
            WebClient downloader 
= new WebClient();
            downloader.OpenReadCompleted 
+= new OpenReadCompletedEventHandler(LoadBlankTxtCompleted);
            downloader.OpenReadAsync(serviceUri);
        }

        
void LoadBlankTxtCompleted(object sender, OpenReadCompletedEventArgs e)
        {
            
if (e.Error == null)
            {
                StreamReader _Reader 
= new StreamReader(e.Result);
                
this.txtBlank.Text = _Reader.ReadToEnd();
            }
            
else
            {
                txtBlank.Text 
= "出错:" + e.Error.Message.ToString();
            }
        }



        
/// <summary>
        
/// 加载wcf返回的文本
        
/// </summary>
        void LoadWcfTxt()
        {
            Uri serviceUri 
= new Uri("http://localhost:7055/Demo.svc/GetData?callBack=123");
            WebClient downloader 
= new WebClient();
            downloader.OpenReadCompleted 
+= new OpenReadCompletedEventHandler(LoadWcfCompleted);
            downloader.OpenReadAsync(serviceUri);
        }

        
void LoadWcfCompleted(object sender, OpenReadCompletedEventArgs e)
        {
            
if (e.Error == null)
            {
                StreamReader _Reader 
= new StreamReader(e.Result);
                
this.txtWcf.Text = _Reader.ReadToEnd();
            }
            
else
            {
                txtWcf.Text 
= "出错:" + e.Error.Message.ToString();
            }
        }

    }
}


wcf的代码也在这里贴出来,就是一"启用了ajax的wcf服务",没啥特别的,下面的代码仅参考(从NorthWind数据库中,读取了表Categories的部分信息)

ContractedBlock.gif ExpandedBlockStart.gif Code
using System.Configuration;
using System.Data;
using System.Data.SqlClient;
using System.IO;
using System.ServiceModel;
using System.ServiceModel.Activation;
using System.ServiceModel.Web;
using JIMMY.TOOLS;

namespace WcfTest.Web
{
    [ServiceContract(Namespace 
= "")]
    [AspNetCompatibilityRequirements(RequirementsMode 
= AspNetCompatibilityRequirementsMode.Allowed)]
    
public class Demo
    {
       
        [OperationContract]
        [WebInvoke(Method 
= "GET", ResponseFormat = WebMessageFormat.Json, UriTemplate = "GetData?callback={callback}")]
        
public Stream GetData(string callback)
        {
            DataTable _Table 
= new DataTable();
            
string _Result = "";
            
using (SqlConnection conn = Database.GetConn(ConfigurationManager.ConnectionStrings["ConnStr"].ToString()))
            {
                
try
                {
                    
string sql = "Select CategoryId,CategoryName,Description from Categories";                 
                    SqlDataReader sdr 
= Database.ExecuteReader(conn, CommandType.Text, sql);
                    _Table 
= Database.ConvertDataReaderToDataTable(sdr);
                }
                
catch { }
                
finally { conn.Close(); }
            }

            
if (_Table.Rows.Count <= 0)
            {
                _Result 
= "var _" + callback + "={Head:[]}";
            }
            
else
            {
                _Result 
= "var _" + callback + "=" + Utils.CreateJsonParameters(_Table);
            }
            
return GetStream(_Result);
        }


        
private Stream GetStream(string str)
        {
            MemoryStream ms 
= new MemoryStream();
            StreamWriter sw 
= new StreamWriter(ms);
            sw.AutoFlush 
= true;
            sw.Write(str);
            ms.Position 
= 0;
            WebOperationContext.Current.OutgoingResponse.ContentType 
= "text/plain";
            
return ms;
        }        
    }
}


最后附上:txt.txt以及json.txt二个测试文本的内容

json.txt内容:

[{'name':"jimmy.yang"},{'name':'yezhouyun'},{'name':123456}]

 

txt.txt内容:

要做到这两点只需要更改一下所示的高两部分即可。第一个高两部分表示我们将NorthwindEntities作为我们的数据源。NorthwindEntities是我们刚才创建的EDMX的类名,Employees等表都已经作为其属性被Mapping成对象。第二个高亮部分是控制EntitySet(其实就是对应的表一级)的访问权限。例如你仍然可以通过下边的代码仅仅暴露Employees对象的只读权限:config.SetEntityAccessRule(“Employees”,EntitySetRights.AllRead.这样,服务只会暴露Employees集合并且只接受读取,而不能有更新操作。

运行效果图如下:

 

目录
相关文章
|
28天前
|
存储 JSON API
淘系API接口(解析返回的json数据)商品详情数据解析助力开发者
——在成长的路上,我们都是同行者。这篇关于商品详情API接口的文章,希望能帮助到您。期待与您继续分享更多API接口的知识,请记得关注Anzexi58哦! 淘宝API接口(如淘宝开放平台提供的API)允许开发者获取淘宝商品的各种信息,包括商品详情。然而,需要注意的是,直接访问淘宝的商品数据API通常需要商家身份或开发者权限,并且需要遵循淘宝的API使用协议。
淘系API接口(解析返回的json数据)商品详情数据解析助力开发者
|
3月前
|
JSON JavaScript 测试技术
掌握JMeter:深入解析如何提取和利用JSON数据
Apache JMeter教程展示了如何提取和使用JSON数据。创建测试计划,包括HTTP请求和JSON Extractor,设置变量前缀和JSON路径表达式来提取数据。通过Debug Sampler和View Results Tree监听器验证提取结果,然后在后续请求和断言中使用这些数据。此方法适用于复杂测试场景,提升性能和自动化测试效率。
126 0
|
1月前
|
JSON 前端开发 API
【淘系】商品详情属性解析(属性规格详情图sku等json数据示例返回参考),淘系API接口系列
在淘宝(或天猫)平台上,商品详情属性(如属性规格、详情图、SKU等)是商家在发布商品时设置的,用于描述商品的详细信息和不同规格选项。这些信息对于消费者了解商品特性、进行购买决策至关重要。然而,直接通过前端页面获取这些信息的结构化数据(如JSON格式)并非直接暴露给普通用户或开发者,因为这涉及到平台的商业机密和数据安全。 不过,淘宝平台提供了丰富的API接口(如淘宝开放平台API),允许有资质的开发者或合作伙伴通过编程方式获取商品信息。这些API接口通常需要注册开发者账号、申请应用密钥(App Key)和秘钥(App Secret),并遵守淘宝的API使用协议。
|
18天前
|
存储 JSON API
Python编程:解析HTTP请求返回的JSON数据
使用Python处理HTTP请求和解析JSON数据既直接又高效。`requests`库的简洁性和强大功能使得发送请求、接收和解析响应变得异常简单。以上步骤和示例提供了一个基础的框架,可以根据你的具体需求进行调整和扩展。通过合适的异常处理,你的代码将更加健壮和可靠,为用户提供更加流畅的体验。
53 0
|
1月前
|
JSON 数据格式 索引
【Azure Developer】Azure Logic App 示例: 解析 Request Body 的 JSON 的表达式? triggerBody()?
【Azure Developer】Azure Logic App 示例: 解析 Request Body 的 JSON 的表达式? triggerBody()?
|
2月前
|
存储 JSON JavaScript
使用JSONObject解析与生成JSON数据
使用JSONObject解析与生成JSON数据
|
2月前
|
JSON 前端开发 JavaScript
Go怎么解析不定JSON数据?
在Go中处理不确定结构的JSON数据,可以使用`map[string]interface{}`来解析,它能适应各种JSON键值对,但需要类型检查。另一种方法是使用`json.RawMessage`保存原始JSON,之后按需解析。此外,`json.Number`用于处理任意精度的数字。当JSON字段类型未知时,可以先解码到`interface{}`并做类型断言。第三方库如gjson和jsonparser提供更灵活的解析选项。
|
2月前
|
JSON 分布式计算 大数据
MaxCompute产品使用合集之如何解析嵌套的JSON数据
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。
103 0
|
2月前
|
JSON Java 数据格式
使用JSONObject解析与生成JSON数据
使用JSONObject解析与生成JSON数据
|
3月前
|
存储 JSON NoSQL
深入解析RedisJSON:在Redis中直接处理JSON数据
深入解析RedisJSON:在Redis中直接处理JSON数据