前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >silverlight动态读取txt文件/解析json数据/调用wcf示例

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

作者头像
菩提树下的杨过
发布2018-01-23 10:17:38
1.4K0
发布2018-01-23 10:17:38
举报

终于开始正式学习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完整内容如下:

代码语言:js
复制
 <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

代码语言:js
复制
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

代码语言:js
复制
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集合并且只接受读取,而不能有更新操作。

运行效果图如下:

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2009-02-06 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档