Amazon AppSync在Android端的部署

AppSync

可以简单地理解这个功能可以做到App前端的数据和AWS上后端的数据同步,App可以对后端的数据进行读写等功能。比如带有同步功能待办事项App,就可以用这个功能实现。

GraphQL

如果你抓取过网页发送的消息包,那么你一定能理解API是个什么东西。假设我们要登陆一个网站,或是在京东获取某个商品的详细规格,我们都需要和服务器进行交互,我们需要告诉服务器我们需要的是一个什么样的东西,同时传递一些必要的参数。比如我们需要“AMD CPU”这个商品第1~50条的评论,我们的API可能就会像下面这样:

{
"item":"AMD CPU",
"type":"comment",
"index_start":1,
"index_end":50
}

然而目前这样的API用起来还是很麻烦的,因为格式都是固定的,想要查特定的某个信息可能会返回其他冗余的信息 ,因此就诞生了GraphQL,它可以更精准方便的查询自己想要的东西。
关于GraphQL更详细的介绍可以看
https://www.howtographql.com/basics/0-introduction/
为了继续后面的研究,这里我们只需要知道GraphQL可以很方便的描述出一个数据的结构,并且和后端的互动一般包含Query和Mutation两种,Query用于读后端数据,Mutation用于修改后端数据。

GraphQL在AWS中的使用

既然GraphQL可以很方便的描述出数据结构,当然也能用作我们构建后端数据库的模型了!AWS中的AppSync确实也是这么做的,设计好一个GraphQL之后,导入到AWS,AWS AppSync能自动根据该GraphQL搭建出对应的数据库。仅仅有数据库还是不够的,怎么样进行Sync呢?当然需要对应的动作啦。例如App发出一个GraphQL查询,AWS需要对该查询做出正确的反应才行,应该如何反应就被称作Resolver,不用担心,AWS会自动帮我们配置好大部分Resolver。下面我们通过例子来学习一下AppSync是怎么一回事。

AppSync Eg

首先我们进入AppSync控制台创建一个新的API,选择Event App


创建模型(这个模型也可以通过GraphQL直接描述)

几步点完之后,我们可以进行测试了,在该验证界面,我们可以看到里面的代码有query mutation两种类型,点击箭头分别运行createA_test_model listA_test_models就可以看到右侧分别返回了对应的结果。


或许有人不理解这是要干什么,这样的查询、创建代码,是在网页控制台用来测试GraphQL是否描述正确的,测试通过后就可以在App上通过同样的查询、创建代码来对后端的数据进行修改了。

详解

我们再来看下整个架构是怎样的。从左边栏目点一下Schema我们可以查到整个API对应的结构,果然代码是GraphQL!


再看一下Data Sources,是Amazon DynamoDB,它是根据上述Schema配置好的。

根据GraphQL配置Resouces

根据GraphQL配置Resouces

另外还有上述提到的Resolver,用于控制对某一条GraphQL命令应该如何返回数据。这里根据教程,假设要对getTodos这个命令做出反馈,步骤如下:
单击Attach

创建反馈机制

创建好之后我们同样进行测试,首先创建一个id=123的TODO

接着我们Query一下

成功返回了我们刚才创建的数据!

Android端设置

通过上述流程我们大致明白了AppSync是怎样的一个东西,并在网页端进行了操作,下面我们进行Android的操作。教程参考:
https://aws-amplify.github.io/docs/android/start
在一个Android工程下输入

amplify init
amplify add api
amplify push



一开始的时候push失败了,报错

Amplify工具是通过CloudFormatiom模板自动部署各种模块的,我们可以去查询一下发生了什么。

通过更新Amplify就可以解决掉这个问题。

npm install -g @aws-amplify/cli -update

发现它同样也创建了一个简单的Schema用于描述我们的数据结构,这一步实现的效果和我们在网页端操作的GraphQL是一致的。


但是在网页上运行的查询、修改命令肯定和Android端用起来是不一样的呀!这该怎么解决?这就是Amplify框架教程里面提到的CodeGen了。在所有命令跑完之后Amplify会自动运行该框架,根据我们设定好的Schema生成出对应的查询、修改等GraphQL命令以及Java代码(所以叫CodeGen嘛!),在Android文件夹里面也是可以看到的。


这里我简单的跑了一下,效果就是点了下很多Add添加Item,然后点Query就可以查询出刚才添加的Item。假如再完善一下界面,就可以做出很棒的TODO App啦。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,245评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,749评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,960评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,575评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,668评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,670评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,664评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,422评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,864评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,178评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,340评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,015评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,646评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,265评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,494评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,261评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,206评论 2 352

推荐阅读更多精彩内容