zoukankan      html  css  js  c++  java
  • 使用Windows Azure Mobile Service开发Windows Phone 8 App【转http://www.cnblogs.com/dlbrant/archive/2013/04/02/2996627.html】

    - How to make a Windows Phone 8 app with Windows Azure Mobile Service

    Windows Azure Mobile Service推出已经有一段时间了,这可能是这段时间以来Windows Azure上最受关注的一个Feature,试用了一下Mobile Service,觉得还不错,分享下试用的过程,供大家参考。

    新建一个Mobile Service

    1. 登陆到Windows Azure Portal,创建一个Mobile Service

    clip_image002[4]

    2. 创建一个Mobile Service:MyTodos,并为之新建一个数据库,注意数据库服务器的区域和Mobile Service的区域最好相同,这样可以减少网络延迟和流量费用 (当然也可以使用已有的数据库实例,Mobile Service会把新建的数据表都放到MyTodos这个Schema下,所以不用担心和原有的表重名)

    clip_image004[4]

    clip_image006[4]

    3. 等待几分钟后,Mobile Service创建完成后,点击MyTodos进行配置:

    a) 平台这里可以看到,Mobile Service支持Windows/ WP8/Android/iOS/Html5的应用,这里我们选择Windows Phone8,注意需要安装两个SDK – Windows Phone 8 SDK和Mobile Service SDK;

    b) 单击“创建TodoItem表”在刚才的数据库中创建一个TodoItem表,当然也可以自己到数据库里创建。

    clip_image008[4]

    clip_image010[4]

    4. 浏览到配置这个页面,注意启用“动态架构”,这样在开发阶段,我们给Mobile Service传什么样的entity,Mobile Service会自动为我们创建相应的字段,但等到发布阶段,出于安全的考虑,最好是把“动态架构”关闭。

    clip_image012[4]

    5. 回到MyTodos的首页,下载Azure自动生成的代码

    clip_image014[4]

    6. 打开刚下载的代码,这时候我们已经得到了一个完整的Windows Phone 8的应用,来看看Mobile Service都生成了什么代码

    a) MobileServiceClient:这就是Mobile Service SDK里面用来访问Mobile Service的客户端

    clip_image016[4]

    b) TodoItem以及相应的Insert/Update/Refresh等方法:注意这些方法都是使用.Net 4.5的异步编程,这也是Mobile Service所推荐的编程模式。

    clip_image017[4]

    7. 运行测试一下这个小App,添加一些TodoItem,浏览之前建的数据库,可以看到,还没有写一行代码,就已经得到了一个完整的WP8 App。

    clip_image019[4]

    clip_image021[4]

    clip_image023[4]

    添加用户验证

    接下来添加用户验证,Mobile Service支持MicrosoftAccount(也就是LiveID)/Google/Facebook/Twritter四种用户验证方式,本文只使用了MicrosoftAccount。

    1. 要使用MicrosofAccount,首先要到Live Connect Developer Center(http://go.microsoft.com/fwlink/p/?linkid=262039&clcid=0x409 )注册一下我们的App,注意“手机客户端应用”选择“是”。

    clip_image025[4]

    clip_image027[4]

    2. 将注册得到的客户端ID和客户端密钥填到Mobile Service上,并保存

    clip_image029[4]

    3. 现在设置一下数据权限,将TodoItem表设为只有验证过的用户才能读写,并保存

    clip_image031[4]

    clip_image033[4]

    4. 再运行一下App,这次应该收到一个Unauthorized异常,因为当前的用户没有登录

    clip_image034[4]

    5. 接下来为App添加登录的代码

    a) 在MainPage.xaml里为MainPage添加一个Login button

    b) 注释掉OnNavigatedTo里面的代码

    View Code

    c) 修改App.xaml.cs里面的ApplicationKey

    View Code

    d) 将下面这段代码添加到MainPage class里

    View Code

    运行看看效果,现在又可以刷新和添加TodoItem了

    clip_image036[6]clip_image038[4]clip_image040[4]

    clip_image042[4]clip_image044[4]

    6. 如果需要得到更多的用户信息,则需要下载并安装LiveSDK( http://msdn.microsoft.com/en-us/live/ff621310 ),并为MyTodos添加引用到Microsoft.Live

    clip_image046[4]

    a) 按下面的代码修改MainPage.Authenticate

    View Code

    运行效果如下,可以看到登录的页面与之前稍有差别,但这次能得到更多的用户信息

    clip_image036[7]clip_image048[4]clip_image050[4]

    clip_image052[4]

    添加推送通知

    1. 添加代码如下

    a) 在App.xaml.cs中添加如下代码

    View Code

    b) 在Application_Launching中调用AcquirePushChannel

    View Code

    c) 给TodoItem class添加一个property

    View Code

    d) 修改MainPage.xaml.cs的ButtonSave_Click,代码如下。由于我们启用的动态架构,所以Save的时候Mobile Service会为新添加的Channel属性创建一个对应的数据库字段。

    View Code

    2. 给App开启推送

    clip_image054[5]

    3. 回到Azure的Portal,修改Mobile Service服务端script并保存,详细参数可以参考这里:

    http://msdn.microsoft.com/en-us/library/windowsazure/jj871025.aspx

    clip_image056[4]

    代码如下:

    View Code

    4. 把MyTodos pin到主界面上,运行app,观察效果

    clip_image058[4] clip_image060[4] clip_image062[4]

    clip_image064[4] clip_image066[4]

    总结

    Azure Mobile Service极大地简化了server端的代码开发,尤其是对于比较小的应用来说,更是非常方便,使App开发者可以专注于前端代码。

    附:

    客户端源代码在这里

  • 相关阅读:
    react深入学习(资料,案例)
    match.exec深入学习
    实用插件表格行列隐藏显示
    下拉选项插件的实现
    表格操作eventTable
    [CentOS7] 挂载iso镜像文件到/media目录下
    [CentOS7] 设置开机启动方式(图形界面或命令行)
    [CentOS7] 磁盘分区(gdisk, fdisk)
    [CentOS7] minimal安装后 出现 没有ifconfig 无法ping 无法yum could not retrieve mirrorlist http://mirrorlist.centos.org/
    [C++]C,C++中使用可变参数
  • 原文地址:https://www.cnblogs.com/songtzu/p/2998419.html
Copyright © 2011-2022 走看看