silverlight动态读取txt文件/解析json数据/调用wcf示例
终于开始正式学习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完整内容如下:
<UserControl x:Class="WcfTest.Page"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
>
<Grid x:Name="LayoutRoot" Background="White" ShowGridLines="True">
<Grid.RowDefinitions>
<RowDefinition Height="*"></RowDefinition>
<RowDefinition Height="*"></RowDefinition>
<RowDefinition Height="*"></RowDefinition>
</Grid.RowDefinitions>
<TextBlock x:Name="txtJson" Grid.Row="0" Grid.Column="0"></TextBlock>
<TextBlock x:Name="txtBlank" Grid.Row="1" Grid.Column="0" TextWrapping="Wrap"></TextBlock>
<TextBlock x:Name="txtWcf" Grid.Row="2" Grid.Column="0" TextWrapping="Wrap"></TextBlock>
</Grid>
</UserControl>
Page.Xaml.cs完整内容如下:
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的部分信息)
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集合并且只接受读取,而不能有更新操作。
运行效果图如下:
- PHP基础——PHP数组
- 使用shell抽取html数据之二(r2笔记75天)
- Python爬取链家网数据:新房楼盘价格分析
- 【编程基础】Java里面如何对字符串排序?
- 计算广告——广告定向实践
- 通过shell抓取html数据(r2笔记74天)
- 通过shell脚本分析足彩(r2笔记74天)
- 通过shell脚本得到数据字典的信息 (r2笔记72天)
- 机器学习算法实践——K-Means算法与图像分割
- 利用 Python、SciKit 和文本分类来构建客户行为描述模型
- 使用Python爬取社交网络数据分析
- PHP爬虫源码:百万级别知乎用户数据爬取与分析
- 使用Python抓取欧洲足球联赛数据
- python爬取百度新闻:分析共享单车火爆背后有哪些规则?
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法