Silverlight+WCF实现跨域调用

      在这篇文章中。WCF扮演server,向外提供LoginVaild服务。Silverlight扮演client。调用WCF提供的LoginVaild服务。思路有了。以下进行代码实现。

  数据库脚本实现

  新建T_User表。在表中加入两个字段username、password,向表中插入一条数据admin admin,脚本例如以下:

USE [test]
GO
/****** Object:  Table [dbo].[T_User]    Script Date: 09/28/2014 21:12:02 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
SET ANSI_PADDING ON
GO
CREATE TABLE [dbo].[T_User](
	[username] [varchar](20) NOT NULL,
	[password] [varchar](20) NOT NULL,
 CONSTRAINT [PK_T_User] PRIMARY KEY CLUSTERED 
(
	[username] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]
GO
SET ANSI_PADDING OFF
GO
INSERT [dbo].[T_User] ([username], [password]) VALUES (N'admin', N'admin')

  WCFserver实现

  1.新建一个WCF服务库项目,在默认生成的IServer1.cs接口在加入LoginVaild服务的声明:

  [OperationContract]
        bool LoginVaild(string userName, string password);
    2.加入ADO.Net实体数据模型文件--Model.edmx。用于对数据表T_User的訪问。

   3.在Service1.svc中对LoginVaild方法进行实现:

 public bool LoginVaild(string userName, string password)
        {
            bool result = false;
            //须要訪问的ADO.Net数据实体模型
            using (SLtestEntitiesSecond entities = new SLtestEntitiesSecond())
            {
                var user = entities.T_User.Where(c => c.username == userName && c.password == password).SingleOrDefault();
                if (user == null)
                {
                    result = false;
                }
                else
                {
                    result = true;
                }

            }
            return result;
        }
        4.在项目的根文件夹加入跨域訪问文件clientaccesspolicy.xml。内容例如以下:

<?xml version="1.0" encoding="utf-8" ?>
<access-policy>
  <cross-domain-access>
    <policy>
      <allow-from http-request-headers="*">
        <domain uri="*"/>   
      </allow-from>
      <grant-to>
        <resource path="/" include-subpaths="true"/>
      </grant-to>    
    </policy> 
  </cross-domain-access>
</access-policy>

  5.设定WCFserver使用特定port进行訪问,方法:选中WCFserver项目-->邮件属性-->Web-->特定port,输入1316。这样保证我们每次能够通过1316port訪问WCF提供的服务。

  到此。WCFserver端配置完毕,选中Service1.svc文件。在浏览器中浏览器下WCF提供的服务。

  Silverlightclient实现

  1.新建Silverlight应用程序。在引用中加入服务引用,在地址栏输入Service1.svc文件在浏览器中的路径,比方我的是:http://localhost:1316/Service1.svc
  2.新建Silverlight用户控件Login.xaml文件,在显示页面加入username、passwordTextBox和登录Button。
  3.在Login.xaml后台通过调用WCF提供的服务对用户输入进行推断,代码例如以下:
    private void button1_Click(object sender, RoutedEventArgs e)
        {
            string userName = txtusername.Text.Trim();
            string password = txtpassword.Text.Trim();
            Service1Client client = new Service1Client();
            client.LoginVaildCompleted += new EventHandler<LoginVaildCompletedEventArgs>(client_LoginVaildCompleted);
            client.LoginVaildAsync(userName, password);
            client.CloseAsync();
        }

        void client_LoginVaildCompleted(object sender, LoginVaildCompletedEventArgs e)
        {
            if (e.Error == null)
            {
                //MessageBox.Show(e.Result.ToString());
                if (e.Result == true)
                {
                    this.Content = new MainPage();

                }
                else
                {
                    MessageBox.Show("用户名或密码错误!");
                }
            }
            else
            {
                MessageBox.Show(e.Error.ToString());
            }
        }
   4.在App.xaml配置文件设置Login.xaml为起始页,代码例如以下:
  private void Application_Startup(object sender, StartupEventArgs e)
        {
            this.RootVisual = new Login();
        }
  到此。client配置完毕,执行Silverlightclient项目就可以查看结果。源代码下载地址:http://pan.baidu.com/s/1mgn3IEO
  如今回首整个实现过程。有点面向服务编程的意思:WCF提供一个服务,然后把訪问服务的接口公开,想调用此服务的项目仅仅要加入此服务的引用便能调用WCF提供的服务。
  在实现过程中,有个问题至今尚未解决,在WCFserver项目中配置ADO.Net实体数据模型时,假设是用SQL Server的SQL Server身份验证方式登录,便会报“server返回了错误 Not found”异常;改成Windows身份验证问题解决。

这是个治标不治本的解决方式。对此问题。希望大神可以给出解释。

转载于:https://www.cnblogs.com/gcczhongduan/p/5241702.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
智慧校园信息化系统解决方案旨在通过先进的信息技术,实现教育的全方位创新和优质资源的普及共享。该方案依据国家和地方政策背景,如教育部《教育信息化“十三五”规划》和《教育信息化十年发展规划》,以信息技术的革命性影响为指导,推进教育信息化建设,实现教育思想和方法的创新。 技术发展为智慧校园建设提供了强有力的支撑。方案涵盖了互连互通、优质资源共享、宽带网络、移动APP、电子书包、电子教学白板、3D打印、VR虚拟教学等技术应用,以及大数据和云计算技术,提升了教学数据记录和分析水平。此外,教育资源公共服务平台、教育管理公共服务平台等平台建设,进一步提高了教学、管控的效率。 智慧校园系统由智慧教学、智慧管控和智慧办公三大部分组成,各自具有丰富的应用场景。智慧教学包括微课、公开课、精品课等教学资源的整合和共享,支持在线编辑、录播资源、教学分析等功能。智慧管控则通过平安校园、可视对讲、紧急求助、视频监控等手段,保障校园安全。智慧办公则利用远程视讯、无纸化会议、数字会议等技术,提高行政效率和会议质量。 教育录播系统作为智慧校园的重要组成部分,提供了一套满足学校和教育局需求的解决方案。它包括标准课室、微格课室、精品课室等,通过自动五机位方案、高保真音频采集、一键式录课等功能,实现了优质教学资源的录制和共享。此外,录播系统还包括互动教学、录播班班通、教育中控、校园广播等应用,促进了教育资源的均衡化发展。 智慧办公的另一重点是无纸化会议和数字会议系统的建设,它们通过高效的文件管理、会议文件保密处理、本地会议的音频传输和摄像跟踪等功能,实现了会议的高效化和集中管控。这些系统不仅提高了会议的效率和质量,还通过一键管控、无线管控等设计,简化了操作流程,使得会议更加便捷和环保。 总之,智慧校园信息化系统解决方案通过整合先进的信息技术和教学资源,不仅提升了教育质量和管理效率,还为实现教育均衡化和资源共享提供了有力支持,推动了教育现代化的进程。
智慧校园信息化系统解决方案旨在通过先进的信息技术,实现教育的全方位创新和优质资源的普及共享。该方案依据国家和地方政策背景,如教育部《教育信息化“十三五”规划》和《教育信息化十年发展规划》,以信息技术的革命性影响为指导,推进教育信息化建设,实现教育思想和方法的创新。 技术发展为智慧校园建设提供了强有力的支撑。方案涵盖了互连互通、优质资源共享、宽带网络、移动APP、电子书包、电子教学白板、3D打印、VR虚拟教学等技术应用,以及大数据和云计算技术,提升了教学数据记录和分析水平。此外,教育资源公共服务平台、教育管理公共服务平台等平台建设,进一步提高了教学、管控的效率。 智慧校园系统由智慧教学、智慧管控和智慧办公三大部分组成,各自具有丰富的应用场景。智慧教学包括微课、公开课、精品课等教学资源的整合和共享,支持在线编辑、录播资源、教学分析等功能。智慧管控则通过平安校园、可视对讲、紧急求助、视频监控等手段,保障校园安全。智慧办公则利用远程视讯、无纸化会议、数字会议等技术,提高行政效率和会议质量。 教育录播系统作为智慧校园的重要组成部分,提供了一套满足学校和教育局需求的解决方案。它包括标准课室、微格课室、精品课室等,通过自动五机位方案、高保真音频采集、一键式录课等功能,实现了优质教学资源的录制和共享。此外,录播系统还包括互动教学、录播班班通、教育中控、校园广播等应用,促进了教育资源的均衡化发展。 智慧办公的另一重点是无纸化会议和数字会议系统的建设,它们通过高效的文件管理、会议文件保密处理、本地会议的音频传输和摄像跟踪等功能,实现了会议的高效化和集中管控。这些系统不仅提高了会议的效率和质量,还通过一键管控、无线管控等设计,简化了操作流程,使得会议更加便捷和环保。 总之,智慧校园信息化系统解决方案通过整合先进的信息技术和教学资源,不仅提升了教育质量和管理效率,还为实现教育均衡化和资源共享提供了有力支持,推动了教育现代化的进程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值