WCF Ria Services(通常称为RIA服务),专门设计让Silverlight应用程序访问数据库,网上有关其示例应用都是基于简单的数据显示,其中MSDN网站上有详细的解决方案介绍,地址http://msdn.microsoft.com/zh-cn/library/ff713719(v=vs.91).aspx,我认为把这个看懂后,你基本上就入门了。

但是由于项目需要,我要把SQL SERVER数据库中以二进制流保存的图片显示到客户端浏览器里,在网上找了很久的资料,都没找到相关的介绍,最后花了不少功夫,终于实现了功能。先看其效果如下:

在数据库中,我们建了一个ImageTable数据库,两列数据ImageId(int)和ImageData(varbinary(MAX)),然后通过下面命令插入初始数据和图片

  1. Use ImageDB;
  2. Go
  3. INSERT INTO ImageTable VALUES (1,(SELECT * FROM OPENROWSET(BULK N'D:\DEC.jpg',SINGLE_BLOB) AS Photo))

  然后新建一个silverlght业务应用程序,添加一个显示此图片的silverlight页,ADO.NET实体数据模型和域服务类,过程可参考前面给出的例子,这里主要说明如何把图片显示出来。

  1. <navigation:Page xmlns:sdk="http://schemas.microsoft.com/winfx/2006/xaml/presentation/sdk" x:Class="ImageTestApp.Views.WorkerImage"
  2. xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  3. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  4. xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
  5. xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
  6. mc:Ignorable="d"
  7. xmlns:local="clr-namespace:ImageTestApp.Views"
  8. xmlns:navigation="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Navigation"
  9. d:DesignWidth="
  10. Title="WorkerImage Page">
  11. <navigation:Page.Resources>
  12. <local:DataToImageConverter x:Key="DataToImageConverter"></local:DataToImageConverter>
  13. </navigation:Page.Resources>
  14. <Grid x:Name="LayoutRoot">
  15. <ScrollViewer x:Name="PageScrollViewer" Style="{StaticResource
  16. PageScrollViewerStyle}" >
  17. <StackPanel x:Name="ContentStackPanel" Style="{StaticResource ContentStackPanelStyle}">
  18.  
  19. <TextBlock Text="图片" Style="{StaticResource HeaderTextStyle}"/>
  20. <sdk:DataGrid AutoGenerateColumns=">
  21.  
  22. <sdk:DataGrid.Columns>
  23. <sdk:DataGridTextColumn Header="序号" Binding="{Binding ImageId}" />
  24. <sdk:DataGridTemplateColumn Header="图片" CanUserResize="False" >
  25. <sdk:DataGridTemplateColumn.CellTemplate>
  26. <DataTemplate>
  27. <StackPanel Orientation="Horizontal" VerticalAlignment="Center">
  28. <!--<TextBox x:Name="imgLogo" Text="{Binding Path=ImageData}" >
  29. </TextBox>-->
  30. <Image x:Name=" Source="{Binding Path=ImageData,Converter={StaticResource DataToImageConverter}}" >
  31. </Image>
  32. </StackPanel>
  33. </DataTemplate>
  34. </sdk:DataGridTemplateColumn.CellTemplate>
  35. </sdk:DataGridTemplateColumn>
  36. </sdk:DataGrid.Columns>
  37.  
  38. </sdk:DataGrid>
  39.  
  40. </StackPanel>
  41. </ScrollViewer>
  42. </Grid>
  43. </navigation:Page>

注意,我们在datagrid前两行定义了两列,序号和图片,由于ImageData是二进制流,无法在图片控件上直接显示,所以图片显示一栏还需要个转化器,下面是后台代码。

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Net;
  5. using System.Windows;
  6. using System.Windows.Controls;
  7. using System.Windows.Documents;
  8. using System.Windows.Input;
  9. using System.Windows.Media;
  10. using System.Windows.Media.Animation;
  11. using System.Windows.Shapes;
  12. using System.Windows.Navigation;
  13.  
  14. using System.Windows.Data;
  15. using System.Windows.Media.Imaging;
  16. using System.IO;
  17. using System.Text;
  18.  
  19. using ImageTestApp.Web;
  20. using System.ServiceModel.DomainServices.Client;
  21.  
  22. namespace ImageTestApp.Views
  23. {
  24. public partial class WorkerImage : Page
  25. {
  26. OrganizationContext _OrganizationContext = new OrganizationContext();
  27. public WorkerImage()
  28. {
  29. InitializeComponent();
  30.  
  31. this.dataGrid1.ItemsSource = _OrganizationContext.ImageTables;
  32. _OrganizationContext.Load(_OrganizationContext.GetImageTableQuery());
  33.  
  34. }
  35.  
  36. }
  37.  
  38. public class DataToImageConverter : IValueConverter
  39. {
  40.  
  41. public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
  42. {
  43.  
  44. BitmapImage bi = new BitmapImage();
  45. bi.SetSource(new MemoryStream((byte[])value));
  46. Image image = new Image();
  47. image.Source = bi;
  48. return bi;
  49.  
  50. //Image image = new Image();
  51. //image.Source = bi;
  52. // return image;
  53.  
  54. }
  55.  
  56. public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
  57. {
  58. throw new NotImplementedException();
  59. }
  60.  
  61. }
  62. }

由于界面里用的Image控件绑定图片,所以刚开始在转换器里需要返回Image类型数据,但实际上此方法行不通,最后看了Image.Source属性才知道应该返回BitmapImage类型,下面是Image的用法:

  1. <Image Width="200" Margin="5" Grid.Column="1" Grid.Row="1" >
  2. <Image.Source>
  3. <BitmapImage UriSource="sampleImages/bananas.jpg" />
  4. </Image.Source>
  5. </Image>

通过此转换器,我们就能将接收到的二进制流转换为图片。如果不通过转换,直接利用datagrid的自动显示功能,图片一栏将显示System.Byte[],让人搞不清楚。此项目还需要完成图片上传功能,后面再加上。

其实在调试过程中,我还有点不明白的是   dataGrid1.ItemsSource 一直看不到接收到的数据,但是客户浏览器里确实已经有了已经有了数据库中的每一项列表。

  

Silverlight应用程序中调用WCF Ria Services访问数据库图片的更多相关文章

  1. Silverlight项目笔记1:UI控件与布局、MVVM、数据绑定、await/async、Linq查询、WCF RIA Services、序列化、委托与事件

    最近从技术支持转到开发岗,做Silverlight部分的开发,用的Prism+MVVM,框架由同事搭好,目前做的主要是功能实现,用到了一些东西,侧重于如何使用,总结如下 1.UI控件与布局 常用的主要 ...

  2. Silverlight项目笔记2:.svc处理程序映射缺失导致的WCF RIA Services异常

    在确定代码.编译结果和数据库都正常的情况下,无法从数据库取到数据.错误提示:Sysyem.Net.WebException:远程服务器返回了错误:NotFound,监听发现请求数据库的服务异常,访问相 ...

  3. WCF RIA Services异常

    .svc处理程序映射缺失导致的WCF RIA Services异常 在确定代码.编译结果和数据库都正常的情况下,无法从数据库取到数据.错误提示:Sysyem.Net.WebException:远程服务 ...

  4. WCF RIA Services使用详解(转载)

    理解领域服务和领域操作 本文目录: 3.1 WCF Ria Services简介 3.1.1 什么是WCF Ria Services 3.1.2 WCF Ria Services如何生成客户端代码 3 ...

  5. Native Application 开发详解(直接在程序中调用 ntdll.dll 中的 Native API,有内存小、速度快、安全、API丰富等8大优点)

    文章目录:                   1. 引子: 2. Native Application Demo 展示: 3. Native Application 简介: 4. Native Ap ...

  6. Consuming Hidden WCF RIA Services

    原文 http://codeseekah.com/2013/07/05/consuming-hidden-wcf-ria-services/ A Silverlight application mad ...

  7. iPhone中调用WCF服务

    本文介绍的是跨平台iPhone中调用WCF服务,WCF是由微软发展的一组数据通信的应用程序开发接口,它是.NET框架的一部分,由 .NET Framework 3.0+开始引入 iPhone中调用WC ...

  8. C++程序中调用WebService的实现

    前言 因为最近的项目中需要运用到在MFC程序中调用WebService里面集成好了的函数,所以特意花了一天的时间来研究WebService的构建以及如何在MFC的程序中添加Web引用,进而来实现在C+ ...

  9. 在网页程序或Java程序中调用接口实现短信猫收发短信的解决方案

    方案特点: 在网页程序或Java程序中调用接口实现短信猫收发短信的解决方案,简化软件开发流程,减少各应用系统相同模块的重复开发工作,提高系统稳定性和可靠性. 基于HTTP协议的开发接口 使用特点在网页 ...

随机推荐

  1. 文件和目录之设置用户ID和设置组ID

    与一个进程相关联的ID有6个或更多,它们如表4-4所示: 表4-4 与每个进程相关联的用户ID和组ID 实际用户ID                            我们实际上是谁 实际组ID ...

  2. java_客户端防表单重复提交和服务器端session防表单重复提交

    用户输入FormServlet链接 FormServlet-〉form.jsp->DoFormServlet FormServlet:产生token,放在session中 form.jsp:hi ...

  3. c++ 模运算

    在数学里,"模运算"也叫"求余运算",用mod来表示模运算. 对于 a mod b 可以表示为 a = q(商)*b(模数) + r(余数),其中q表示商,b表 ...

  4. VS2012 编译GDAL

    先安装VS 2012, 然后下载GDAL最新版本代码,解压. 用管理员权限打开Developer Command Prompt for VS2012终端,进入代码目录. 然后运行命令: nmake / ...

  5. /lib /usr/lib /usr/local/lib 的区别

    /lib是内核级的,/usr/lib是系统级的,/usr/local/lib是用户级的. /lib/ — 包含许多被 /bin/ 和 /sbin/ 中的程序使用的库文件.目录 /usr/lib/ 中含 ...

  6. C语言局部变量和全局变量问题汇总

    1.局部变量能否和全局变量重名? 答:能,局部会屏蔽全局.要用全局变量,需要使用"::" 局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变 ...

  7. HTML兼容总结

    所有浏览器 通用 (市面上主要用到的IE6 IE7 FF)height: 100px; IE6 专用 _height: 100px; IE6 专用 *height: 100px; IE7 专用 *+h ...

  8. 倒影(box-reflect)

    box-reflect: 语法:box-reflect:none | <direction> <offset>? <mask-box-image>?因为不是w3c标 ...

  9. SDK 组件 Qupaisdk 启动出错,错误消息为 [Qupaisdk], the android stack error message is Fail to start the plugin, which is caused by Failed resolution of: Lcom/duanqu/qupai/recorder/R$array;

    紧急解决办法: 将你的oneSDK(qupaiSDK)里面的manifest的pageckage改为:com.duanqu.qupai.recorder

  10. content = "IE=edge,chrome=1" 详解

    content = "IE=edge,chrome=1" 详解 < meta http-equiv = "X-UA-Compatible" content ...