Parse|Parse Server与Android SDK的简单使用

Parse SDK使用记录 Parse是BaaS(Backend as a Service)的先驱, 它可以对多终端的资源进行管理, 发布通知等. 大大简化了后端的开发难度. 废话不多讲, 用过才知道,莽夫就是干!
Server 服务端 安装Parse Server
【Parse|Parse Server与Android SDK的简单使用】Parse Server需要Node.js与MongoDb, 安装方法不赘述, 到处都是
要是实在懒可以尝试以下方法

$ sh <(curl -fsSL https://raw.githubusercontent.com/parse-community/parse-server/master/bootstrap.sh) $ npm install -g mongodb-runner $ mongodb-runner start $ npm start

真香! 还是一键脚本舒服.. 按照提示输入一些配置信息
出现下图表示server安装成功

Jietu20181208-001833@2x.jpg Dashboard 仪表盘 在Server安装完成后, 所有的功能都有了, 但是不能可视化的看到后台的数据, 所以更Geek的做法是安装一个Dashboard
npm install -g parse-dashboard
安装完成之后, 命令号执行
parse-dashboard --appId yourAppId --masterKey yourMasterKey --serverURL "https://example.com/parse" --appName optionalName
这里的配置信息可以在Server的安装目录下的config.json文件找到, 将其更改到你的配置.
运行之后打开http://0.0.0.0:4040/apps
如果看到下图, 说明你Dashboard又安装成功了.

Jietu20181208-003006@2x.jpg
Client 客户端 Client是指端设备 Android/iOS/Web. 因为Parse提供API接口, 同时也提供各个平台的SDK, 使得Parse可以成为许多平台的后端. 这里主要以Android为例. (iOS我也不会)
安装依赖
添加软件源 首先在build.gradle(Project: XXX)中添加
allprojects { repositories { ... maven { url "https://jitpack.io" } } }

这里是为maven仓库添加一个新的软件源
Easy to use package repository for Git. Publish your JVM and Android libraries
摘自jitpack.io 大体意思是说jitpack是个JVM/Android包仓库, 很多github/gitee等社区的库都会被发布在这里.
添加依赖项 其次, 在build.gradle(Module:app)中添加
dependencies { implementation "com.github.parse-community.Parse-SDK-Android:parse:latest.version.here" }

上述代码摘自Github官方README.md 有个注意的是 代码有部分是placeholder latest.version.here 目的是让你使用最新版, 目前最新版是1.18.5, 把latest.version.here替换成1.18.5, 然后Sync, Sync成功后, 依赖就安装完成了.
如何使用
创建Application 首先, 要创建一个Application, 此Application非彼Application, 不是APP. Application/Service/Activity同为系统组件. 等等也许你又问了:
Activity我知道, Application是个啥?
Application和Activity,Service一样,是android框架的一个系统组件,当android程序启动时系统会创建一个 application对象,用来存储系统的一些信息。通常我们是不需要指定一个Application的,这时系统会自动帮我们创建,如果需要创建自己 的Application,也很简单创建一个类继承 Application并在manifest的application标签中进行注册(只需要给Application标签增加个name属性把自己的 Application的名字定入即可)。
android系统会为每个程序运行时创建一个Application类的对象且仅创建一个,所以Application可以说是单例 (singleton)模式的一个类.且application对象的生命周期是整个程序中最长的,它的生命周期就等于这个程序的生命周期。因为它是全局 的单例的,所以在不同的Activity,Service中获得的对象都是同一个对象。所以通过Application来进行一些,数据传递,数据共享 等,数据缓存等操作。
在项目新建一个类, 然后继承自Application
具体代码如下, 如何新建一个Class, 我不想说!!!
public class ApplicationStarter extends Application{ @Override public void onCreate() { super.onCreate(); Parse.enableLocalDatastore(this); Parse.initialize(new Parse.Configuration.Builder(this) .applicationId("pZJJ7iSBoWNcN6sFYFvaFHSVX4RhBpKtk6E1AZti") .clientKey("X5bmnE9IYdVnWd1Ps7Tn7p6sbEtIIP213JnT3tFx") .server("http://10.0.2.2:1337/parse/") // for debug only! localhost .build() ); ParseUser.enableAutomaticUser(); ParseACL acl = new ParseACL(); acl.setPublicReadAccess(true); acl.setPublicWriteAccess(true); ParseACL.setDefaultACL(acl, true); } }

如果使用安卓模拟器, 主机的IP为10.0.2.2:1337, 远端服务器就为公网IP
注册Application 由于我们手工创建, Android Studio没有自动为我们注册. 所以我们要去Manifest文件里注册这个Application
在Manifest文件中, 为application标签添加android:name属性, 值为.ApplicationStarter
修改完成后, 部分如下

测试一下! 在刚刚的ApplicationonCreate方法中,添加如下代码
ParseObject object = new ParseObject("ExampleObject"); object.put("name","zhu bing"); object.put("age","20"); object.saveInBackground(new SaveCallback() { @Override public void done(ParseException e) { if(e == null){ Log.i("Parse","save successfully"); }else{ Log.i("Parse", "save unsuccessfully! " + e.toString()); } } });

然后运行, 编译一定会通过的. 然后去Dashboard看一下是不是出现了新的record

Jietu20181208-004241@2x.jpg
如果是, 那么恭喜! Parse已经可以用了.
注意我这里的服务器地址配置, 我是在模拟器上运行, 如果你不是, 那就改掉它

    推荐阅读