微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

零基础学通Silverlight48:WCF RIA Service

Windows通信基础(Windows Communication FoundationWCF)是应用程序互相通信的框架,是实现简单对象访问协议(SOAPWeb服务的常见方式,使用该框架,开发人员可以构建跨平台、安全、可靠和支持事务处理的企业级互联应用解决方案,提供了动态、低耦合、互联的应用程序通信功能,并大大降低了系统的复杂性,使开 发人员能够关注业务逻辑的实现。
Silverlight 是一种客户端执行的环境,它无法如同 ASP.NET一样,直接与后端数据源进行沟通,数据存读取和保存全都必须跨越网络,我们就必须使用N-tier架构才能让 Silverlight 顺利的存取远程数据,WCF RIA Service 让开发多层式架构的过程就如同传统 2 层式架构应用程序一般自然。支持TCP通讯,比较HTTP提升3-5倍,限于4502-4534端口。简化WCF RIA Services应用开发过程,通过RIA Services轻松存取数据源。
新建项目,注意选中“ Enable WCF RIA Service ”。

     开启数据库服务,sqlserver2005(Express版),为了便于管理,你还需要去下一个manage管理器,安装好manage管理器后, 开启sql2005连接功能,开启办法如下,配置工具->sql server外围应用配置器->服务和连接的外围应用配置器,点击启动,如图

     数据库启动后,添加数据库新项。如图

数据库添加后,项目中出现数据库文件时表明建立成功

 

     健打开数据库,并 选中Tables->右键->新建表(Add New Table)

 

◎ 定义三个字段姓名Name、地址Address、电话Phone,定义Name为主健,并保存为表名Friend

 

     现在我们需要一个数据访问层, RIA 的服务支持 LINQ sql 的框架。增加一个新项目“ ADO.NET Entity Data Model. ”到 Web 项目中。名称 FriendModel.edmx

     选择从数据库中建立模型。

定义数据库连接,选中我们的 MyDatabase.mdf 数据库进行连接。
     选择数据库内的数据表、示图、存储过过程等。这里我们只要选取 Friend 表即可,点击“Finish”完成。

此时需编译一下Shift+F6。下面创建域名服务,域名服务是为RIA的关健。通过创建一个在网络域名服务项目,生成相应的在客户端访问的代码,现是一个本地数据存储,没有Web服务配置,连接字符串等。

     添加新建项中选择"Domain Service Class”,命名为:FriendDomainService.cs

     定义Domain Data Class的参数,这里我们要把EntitiesFunSLUsersEnable editing都钩上.Generate associated calsses for Metadata是集成强大数据展示的定义集,一般建议把空上也钩上,集成了例如:正则表达式等数据效验功能.如下图

 

需再次编译一下,以使Domain Data Class生效到Silverlight项目中,下面进行silverlight端的数据操作。

◎以下是MainPage.xaml内容, 定义了一个Gridview控件用来显示数据,三个按扭控件分别是添加修改删除.

@H_518_502@<UserControl x:Class="Ch16_Exam3_2.MainPage"
@H_518_502@    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
@H_518_502@    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
@H_518_502@    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
@H_518_502@    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
@H_518_502@    mc:Ignorable="d"
@H_518_502@    d:DesignHeight="300" d:DesignWidth="400"
@H_518_502@<!-- 增加SDK 客户端库程序集命名空间支持 -->
@H_518_502@xmlns:sdk="http://schemas.microsoft.com/winfx/2006/xaml/presentation/sdk"
@H_518_502@xmlns:riaControls="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.domainservices" xmlns:my="clr-namespace:Ch16_Exam3_2.Web">
@H_518_502@    <Grid x:Name="LayoutRoot">
@H_518_502@        <sdk:DataGrid AutoGenerateColumns="True" Height="197" HorizontalAlignment="Left" Margin="37,33,0" Name="dataGrid1" VerticalAlignment="Top" Width="322" />
@H_518_502@        <Button Content="添加" Height="39" HorizontalAlignment="Left" Margin="55,250,0" Name="btAdd" VerticalAlignment="Top" Width="90" FontSize="15" Click="btAdd_Click" />
@H_518_502@        <Button Content="删除" Height="40" HorizontalAlignment="Left" Margin="170,249,0" Name="btDele" VerticalAlignment="Top" Width="86" FontSize="15" />
@H_518_502@        <Button Content="修改" Height="39" HorizontalAlignment="Left" Margin="271,0" Name="btAdapt" VerticalAlignment="Top" Width="84" FontSize="15" />
@H_518_502@    </Grid>
@H_518_502@</UserControl>

 

菜单Data”下“Show Data Sources”,可看到数据源FridendContext,在代码在可直接使用了。

 

◎以下是MainPage.xaml.cs文件代码部份。也就是我们开始通过.net ria service操作数据库了。

@H_518_502@using Ch16_Exam3_2.Web;//后手动直接添加的命名的空间
@H_518_502@namespace Ch16_Exam3_2
@H_518_502@{
@H_518_502@    public partial class MainPage : UserControl
@H_518_502@    {             
@H_518_502@        FridendContext fridendcontext;      
@H_518_502@        public MainPage()
@H_518_502@        {
@H_518_502@            InitializeComponent();
@H_518_502@            fridendcontext= new FridendContext();
@H_518_502@            LoadData();
@H_518_502@        }
@H_518_502@        void LoadData()
@H_518_502@        {       
@H_518_502@            dataGrid1.ItemsSource = fridendcontext.Friends;
@H_518_502@            fridendcontext.Load(FridendContext.GetFriendQuery());
@H_518_502@        }
@H_518_502@//增加记录
@H_518_502@        private void btAdd_Click(object sender,RoutedEventArgs e)
@H_518_502@        {
@H_518_502@            Friend fid = new Friend();
@H_518_502@         fid.Name = "张刚"+System .DateTime .Now .Millisecond.ToString ();
@H_518_502@            fid.Address = "内蒙古市";
@H_518_502@            fid.Phone = "87663560";
@H_518_502@            fridendcontext.Friends.Add(fid);
@H_518_502@            fridendcontext.SubmitChanges();
@H_518_502@            MessageBox.Show("增加成功");          
@H_518_502@        }
@H_518_502@//删除记录
@H_518_502@        private void btDele_Click(object sender,RoutedEventArgs e)
@H_518_502@        {
@H_518_502@            Friend fid = (Friend)dataGrid1.SelectedItem;
@H_518_502@            fridendcontext.Friends.Remove(fid);
@H_518_502@            fridendcontext.SubmitChanges();
@H_518_502@            MessageBox.Show("删除成功");
@H_518_502@        }
@H_518_502@//修改记录
@H_518_502@        private void btAdapt_Click(object sender,RoutedEventArgs e)
@H_518_502@        {
@H_518_502@            Friend fid = (Friend)dataGrid1.SelectedItem;
@H_518_502@            fid.Address = "北京市南京路";
@H_518_502@            fridendcontext.SubmitChanges();
@H_518_502@            MessageBox.Show("修改成功");
@H_518_502@        }
@H_518_502@    }
@H_518_502@}

 

增加删除修改等,如图

 

 
更详细内容及源代码下载:
http://www.amazon.cn/mn/detailApp/ref=sr_1_1?_encoding=UTF8&s=books&qid=1287058088&asin=B0043RT7I2&sr=8-1

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐