本章主要讲解利用比目网络科技有限公司提供的Bmob 后端云进行小程序后端开发。
Bmob 后端云专注于为移动应用提供一整套后端云服务 , 能帮助开发者免去几乎所有服务器端的编码工作 , 大幅度降低开发成本和开发时间。

注册Bmob账号

首先,登录Bmob 后端云官网地址(https://www.bmobapp.com),点击右上角的注册按钮,在跳转页面填入姓名、邮箱,并设置密码,确认后到邮箱激活Bmob账户,即可拥有Bmob账号。

1.输入bmob网址:

2.扫码关注公众号:

3.注册新账号

bmob-WeApp-sdk下载Bmod SDK,解压下载后的SDK,把bmob. js和underscore. js文件放到相应的位置。例如,要放到小程序的utils目录中,则在其他需要使用的页面添加以下代码:

var Bmob =require('../../utils/bmob.js');

在小程序项目中的app. js中加入下面两行代码进行全局初始化:

var Bmob = require('utils/bmob.js'); Bmob.initialize("你的 Application ID","你的 REST API Key");

!!! ("你的 Application ID","你的 REST API Key")双引号里的内容需要你去微信小程序平台获取自己的Application 和 REST API Key。

并把下载的安装包复制到目录中

数据的增、删、改、查

为了便于在Bmob中实现数据的增加、删除、修改、查询,我们在新建的应用中新增“test”表,并在表中添加id(编号)、title(标题)、content(内容)、image(图像)字段。

在应用项目中新添加“df”表

创建表及字段

在“df”表中添加id、title、content、image列,Bmob提供Number、String、Boolean、Date、File、Geopoint、Array、Object、Pointer、Relation共10种字段类型。

var Test =Bmob.Object.extend("test");//创建类 var test=new Test();//创建对象 test.set("title","WXML");//添加title 字段内容 test.set("content","Weixin Markup Language 微信标记语言");//添加content字段内容/添加数据,第一个入口参数是nu11 test.save(null,{ success:function(result){ //添加成功,返回成功之后的 objectId(注意:返回的属性名字是 id,不是 objec-Id),你还可以在Bmob的web管理后台看到对应的数据 console.log("添加成功,objectId:"+result.id); error:function(result,error){//添加失败 console.log('添加失败');

运行效果如下:

var Test =Bmob.Object.extend("test"); var query = new Bmob.Query(Test); query.get("d2bb8f2bea",{ success:function(result){ //The object was retrieved successfully. console.log("该记录标题为"+result.get("title")); console.log("该记录的内容为"+result.get("content")); error:function(result,error){ console.log("查询失败");

修改一条记录

如果要修改一条记录,则首先需要获取更新后的Bmob. Object对象,将值修改后保存数据就可以了。

案例代码如下:

//.wxml <button type="primary" bindtap='modi'>修改记录</button> //.js var Bmob =require('../../utils/bmob.js'); Page({ data:{ modi:function(){ var Test = Bmob.Object.extend("test"); var query =new Bmob.Query(Test); //这个id是要修改条目的id,当该id生成并存储成功时可以获取到 query.get("5225bb7d16",{ success:function(result){ //回调中可以取得这个diary对象的一个实例,然后就可以修改它了 result.set('title',"WxSS"); result.set('content',"WenXin Style Sheets"); result.save(); //The object was retrieved successfully. console.log("修改成功") console.log("该记录标题修改为"+result.get("title")) console.log("该记录内容修改为"+result.get("content")) error:function(object,error){ console.log("修改失败")

在代码中 query.get("5225bb7d16",双引号中是自己表中Id数。

运行效果如下

查询所有数据

为了获取某个数据表中的所有数据,我们可以通过Bmob提供的Query对象来实现。

案例代码如下:

//.wxml <button type="primary" bindtap='queryall'>获取所有数据记录</button> //.js var Bmob =require('../../utils/bmob.js'); Page({ data:{ queryall:function(){ var Test = Bmob.Object.extend("test"); //test数据表 var query = new Bmob.Query(Test);//查询所有数据 query.find({ success:function(results){ console.log("共查询到"+results.length+"条记录");//循环处理查询到的数据 for(var i=0; i<results.length;i ++){ var object =results[i]; console.log(object.id +'-' + object.get('title') +'-'+object.get('content')); error:function(error){ console.log("查询失败:"+error.code +""+error.message);

运行效果如下

删除一条记录

删除一条记录可以使用Bmob.Object的destroy方法。

案例代码如下

//.wxml <button type="primary" bindtap='del'>删除记录</button> //.js var Bmob =require('../../utils/bmob.js'); Page({ data:{ del:function( ){ var Test = Bmob.Object.extend("test"); var query = new Bmob.Query(Test); query.get("5225bb7d16",{ success:function(object){ //The object was retrieved successfully. object.destroy({ success:function(deleteObject){ console.log("删除记录成功"); error:function(error){ console.log("删除记录失败"); error:function(object,error){ console.log("修改失败")

在代码中 query.get("5225bb7d16",双引号中是自己表中Id数。

Bmob中提供的查询方法主要有:等于(equalTo)、不等于(notEqualTo)、小于(lessThan)、小于等于(lessThanOrEqualTo)、大于(greaterThan)、大于等于(greaterThanOrEqualTo)等。

示例代码如下:

//.wxml <button type="primary" bindtap='wherequery'>条件查询</button> //.js var Bmob =require('../../utils/bmob.js'); Page({ data:{ //条件查询 wherequery:function(){ var Test = Bmob.Object.extend("test"); var query =new Bmob.Query(Test); query.equalTo("title","WXML"); //查询 title等于“WXML”的记录//查询所有数据 query.find({ success:function(results){ console.log("共查询到"+results.length+"条记录");//循环处理查询到的数据 for(var i=0; i < results.length;i ++){ var object =results[i]; console.log(object.id +'- '+ object.get('title')); error:function(error){ console.log("查询失败:"+error.code +"" + error.message);

照指定条数为一页来显示,这时可以使用limit方法限制查询结果的数据条数来进行分页。默认情况下,limit的值为10,最大有效设置值为1000。

query.limit(10);

同时,skip方法可以做到跳过查询的前多少条数据来实现分页查询的功能。skip的默认值为10。

query.skip(10); 上传一张图片并显示   Bmob提供了文件后端保存功能。利用这一功能,我们可以把本地文件上传到Bmob后台,并按上传日期为文件命名。

示例代码如下:

.wxml代码如下:

<button type="primary" bindtap='upimage'>上传一张图片</button> <image src ="{ {url}}"> </image>

.js代码如下:

var Bmob =require('../../utils/bmob.js'); Page({ data:{ url:"" //上传一张图片 upimage:function(){ var that =this; wx.chooseImage({ count:1,//默认值为9 sizeType: ['compressed'],//可以指定是原图还是压缩图,默认二者都有 sourceType: ['album','camera'],//可以指定来源是相册还是相机,默认二者都有 success:function(res){ var tempFilePaths = res.tempFilePaths; if(tempFilePaths.length >0){ var newDate = new Date(); var newDateStr =newDate.toLocaleDateString();//获取当前日期为文件主名 var tempFilePath =[tempFilePaths[0]]; var extension = /\.([^.]*)$/.exec( tempFilePath[0]);//获取文件扩展名 if(extension){ extension =extension[1].toLowerCase(); var name = newDateStr + "." + extension;//上传的图片的别名 console.log("ll"+name); console.log("ll"+tempFilePaths); var file = new Bmob.File(name,tempFilePaths); file.save().then( function(res){ console.log("ll"+res.name()); console.log("ll"+res.url()); var url=res.url(); that.setData({ url:url function(error){ console.log(error);

运行效果如下:

//.wxml <button type="primary" bindtap="uppic">上传多张照片</button> <block wx:for="{ {list}}" wx:key="this"> <image src="{ {url}}"></image> </block> //.js const { File } = require('../../utils/bmob.js'); var Bmob =require('../../utils/bmob.js'); Page({ data:{ //上传多张照片 uppic:function(){ var that = this; wx.chooseImage({ count:9,//默认值为9 sizeType:['compressed'],//可以指定为压缩图或原图,默认两者都有 sourceType:['album','camera'],//相册还是相机,默认两者都有 success:function(res){ wx.showNavigationBarLoading() that.setData({ loading:false var urlArr=new Array(); var tempFilePaths = res.tempFilePaths; console.log(tempFilePaths) var imgLength=tempFilePaths.length; if(imgLength>0){ var newDate=new Date(); var newDateStr=newDate.toLocaleDateString();//获取当前日期文件 var j=0; for(var i=0;i<imgLength;i++){ var tempFilePath=[tempFilePaths[i]]; var extension =/\.([^.]*)$/.exec(tempFilePath[0]);//获取文件扩展名 if(extension){ extension=extension[1].toLowerCase(); var name=newDateStr+"."+extension;//上传图片别名 var file=new Bmob.File(name,tempFilePath); file.save().then(function(res){ wx.hideNavigationBarLoading() var url=res.url(); console.log("第"+i+"张Url"+url); that.setData({ url:url urlArr.push({"url":url}); that.setData({ list:urlArr console.log(list) console.log(j.imgLength); if(imgLength==j){ console.log(imgLength,urlArr); //如果担心就可以去掉这几行注释 showPic(urlArr,that)//显示图片 },function(error){ console.log(error);
我们结对项目想做一款关于失物招领的APP,我们在讨论过程中关于数据存储是应放在本地还是云端发生了争执,经过多次探讨与利弊分析,最终决定使用 Bmob 后端云 来存储数据。因为 Bmob 云端存储更加方遍用户存取信息,更好的保护数据安全,同时提供了一个方便的数据管理后台。 注册 Bmob 账号(搜索 Bmob 官网,点击注册即可) 在 bmob 中,一个用户可以创建多个应用,每个应用拥有其所属的专用数...
一: 后端云 设置 1.登录 Bmob 后端云 网站https://www. bmob .cn/ ,注册一个新账号,登录后创建新项目 2.应用设置界面保存一下Application ID,SDK初始化必须用到此密钥 二:APP源码添加(Android Studio集成) 1.Project项目的build.gradle里面添加allprojects { repositories {
该款APP是一个后台基于 bmob 后端云 的校园社交APP,后台采用 bmob 云存储技术。界面采用了谷歌的matrial design设计,框架基于MD+Rxjava+retrofit+MVP架构。 到目前为止,已经完成的功能模块有单聊,群聊,附近人搜索,开心时刻,天气预报,朋友圈发表和个人信息编辑展示等7大功能模块。 首先郑重声明下,该聊天功能的实现并不是调用官方的即时通讯API,而是本人自己结合官方提供的推送功能和实时同步的功能,按照自己的逻辑来实现的,所以内部聊天信息的逻辑处理过程源码是开放的,希望对想学习Android聊天框架的同学有所帮助。 项目详解地址:http://www.jianshu.com/p/2d76430617ae 二、screenshot
最近在使用 后端云 Bmob 对数据进行存储,目的是在不搭建服务器的前提下,能对Android应用的数据进行操作处理。 一、创建账号 需要的自己去注册, 后端云 Bmob 首页地址:https://www. bmob .cn/ 二、网站后台创建应用(如图) 这里使用的是免费版的 创建成功之后点击创建的应用进去,在设置-&amp;gt;应用秘钥中可以找到应用秘钥 三、AndroidStudio SDK导入信息配置 详细...
EBankInterface.dll EAS.MicroKernel.dll EAS.Distributed.Contracts.dll EAS.Distributed.Client.dll