比目后端云简介
一个完整的小程序系统,不但需要前端的展现,而且需要后端服务器的支撑,以提供数据服务。也就是说,开发一个真正完整的小程序应用,需要前后端的相互配合。小程序与远程服务器之间通过HTTPS传输协议进行数据交换。
除了自己搭建服务端以外,还可以利用一些网络公司提供的云服务来进行小程序后端的相应开发。本章主要讲解利用比目网络科技有限公司提供的Bmob后端云进行小程序后端开发。
Bmob后端云专注于为移动应用提供一整套后端云服务,能帮助开发者免去几乎所有服务器端的编码工作,大幅度降低开发成本和开发时间。
Bmob提供了小程序软件开发工具包(Software Development Kit, SDK),让用户拥有强大的后端服务。嵌入Bmob小程序SDK后,开发工程师可以更加专注于编写前端代码和优化良好的用户体验,而不必担心后端的基础设施。
Bmob提供了成熟的WebSocket信道服务,降低了开发者使用WebSocket通信的门槛。同时也满足了小程序需要HTTPS与服务端通信的需求。
Bmob还提供了短信验证功能,只需几行简单的代码,即可实现微信小程序的用户登录、富媒体文件上传、发送短信通知和微信支付等功能。
总之,Bmob让微信小程序的开发更简单。
注册Bmob账号
首先,登录Bmob 后端云官网地址(https://www.bmobapp.com),点击右上角的注册按钮,在跳转页面填入姓名、邮箱,并设置密码,确认后到邮箱激活Bmob账户,即可拥有Bmob账号。
创建应用
进入后台,单击左边的“应用”图标,会出现在已经创建的应用项目列表和“创建应用”按钮。单击“创建应用”按钮,填写完成应用的相关信息后,即可创建一个等待开发的应用。
配置小程序密钥
进人后台,选择应用项目,单击“设置”一“应用配置”选项,将小程序中的 AppID(小程序ID)和AppSecret(小程序密钥)填写到Bmob中
获取微信小程序服务器域名和“应用密钥”
进入后台,选择应用项目,单击“设置”一“应用配置”选项,在该界面中可以得到“微信小程序服务器域名配置”(在小程序配置中需要使用)
单击进入后台,选择应用项目,单击“设置”→“应用密钥”选项,可以直接获取应用项目的Application ID和SecretKey(在小程序开发中需要使用)
小程序中配置“安全域名”
登录微信公众号平台,单击“设置”,开发设置选项,在服务器域名中输入获取的合法域名。
下载及安装Bmob SDK
登录 htps:/ github.com/bmob/bmob-WeApp-sdk 下载 Bmod SDK,解压下载后的SDK把bmob-min.js和 underscore.js文件放到相应的位置。
在其他需要使用的页面添加以下代码:
var Bmob=require('./utils/bmob')
同时,在小程序项目中的app.js中加入下面两行代码进行全局初始化:
var Bmob = require('utils/bmob.js');
Bmob.initialize("你的Application ID","你的 REST API Key");
数据的增、删、改、查
为了便于在Bmob中实现数据的增加、删除、修改、查询,我们在新建的应用中新增“test”表,并在
表中添加id(编号)、tie(标题)、content(内容)、image(图像)字段
创建表及字段
在“test”表中添加id、title、content、image列,Bmob 提供 Number、String、BooleanDate、File、Geopoint、Array、0bject、Pointer、Relation共10 种字段类型
在“更多”选项卡里可以实现快速导入/导出数据、删除/编辑表、编辑/删除列等操作。
添加一条记录
添加一条记录用来实现把从前端获取的数据添加到服务端数据表中,主要用 Bmob 提供的SDK对象实现。
代码如下
WXML
<button type="primary" bind:tap="add">添加记录</button>
JS
add:function(){
var Test = Bmob.Object.extend("test");
var test = new Test();
test.set("title","WXML");
test.set("content","Weixin Markup Language 微信标记语言");
test.save(null,{
success:function(result){
console.log("添加成功,objectId:" + result.id);
},
error:function(result,error){
console.log('添加失败');
}
});
},
运行结果:
获取一条记录
WXML
<button type="primary" bind:tap="query">获取记录</button>
JS
query:function(){
var Test = Bmob.Object.extend("test");
var query = new Bmob.Query(Test);
query.get("bad5e2c502",{
success:function(result){
console.log("该记录标题为"+result.get("title"));
console.log("该记录的内容为"+result.get("content"));
},
error:function(result,error){
console.log("查询失败");
}
})
},
运行结果:
修改一条记录
WXML
<button type="primary" bind:tap="modi">修改记录</button>
JS
modi:function(){
var Test = Bmob.Object.extend("test");
var query = new Bmob.Query(Test);
query.get("bad5e2c502",{
success:function(result){
result.set('title',"WXSS");
result.set('content',"WenXin Style Sheets");
result.save();
console.log("修改成功")
console.log(("该记录标题修改为"+result.get("title")));
console.log(("该记录内容修改为"+result.get("content")));
},
error:function(Object,error){
console.log("修改失败")
}
})
}
运行结果:
删除一条记录
WXML
<button type="primary" bind:tap="del">删除一条记录</button>
JS
del:function(){
var Test = Bmob.Object.extend("test");
var query = new Bmob.Query(Test);
query.get("bad5e2c502",{
success:function(deleteObject){
console.log("删除记录成功");
},
error:function(Object,error){
console.log("删除记录失败");
}
});
},
error:function(Object,error){
console.log("修改失败");
}
查询所有数据
WXML
<button type="primary" bind:tap="queryall">获取所有数据记录</button>
JS
queryall:function(){
var Test = Bmob.Object.extend("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(console));
}
},
error:function(error){
console.log("查询失败:"+error.code+""+error.message);
}
})
}
运行结果
条件查询
WXML
<button type="primary" bind:tap="wherequery">条件查询</button>
JS
wherequery:function(){
var Test = Bmob.Object.extend("test");
var query = new Bmob.Object.Query(Test);
query.equalTo("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)
}
})
}
分页查询
query。limit(10);
query.skip(10)
上传图片
上传一张图片并显示
WXML
<button type="primary" bind:tap="upimage">上传一张图片</button>
<image src="{{url}}"></image>
JS
upimage:function(){
var that =this;
wx.chooseImage({
count:1,
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(""+name);
console.log(""+tempFilePaths);
var file = new Bmob.File(name,tempFilePaths);
file.save().then(
function(res){
console.log(""+res.name());
console.log(""+res.url());
var url=res.url();
that.setData({
url:url
})
},
function(error){
console.log(error);
}
)
}
}
})
}
运行结果
本章小结
介绍了一个完整的小程序项目需要前后端两大部分,介绍了Bmob后端的注册,后台配置,在Bmob中如何实现数据的增加,删除,修改,查询及图片文件的上传。