8.1 比目后端云简介
一个完整的小程序系统,不但需要前端的展现,而且需要后端服务器的支撑,以提供数据服务。也就是说,开发一个真正完整的小程序应用,需要前后端的相互配合。小程序与远程服务器之间通过HTTPS传输协议进行数据交换,如图所示。
除了自己搭建服务端以外,还可以利用一些网络公司提供的云服务来进行小程序后端的相应开发。本章主要讲解利用比目网络科技有限公司提供的Bmob后端云进行小程序后端开发。
Bmob后端云专注于为移动应用提供一整套后端云服务,能帮助开发者免去几乎所有服务器端的编码工作,大幅度降低开发成本和开发时间。
Bmob提供了小程序软件开发工具包(Software Development Kit, SDK),让用户拥有强大的后端服务。嵌入Bmob小程序SDK后,开发工程师可以更加专注于编写前端代码和优化良好的用户体验,而不必担心后端的基础设施。
Bmob提供了成熟的WebSocket信道服务,降低了开发者使用WebSocket通信的门槛。同时也满足了小程序需要HTTPS与服务端通信的需求。
Bmob还提供了短信验证功能,只需几行简单的代码,即可实现微信小程序的用户登录、富媒体文件上传、发送短信通知和微信支付等功能。
总之,Bmob让微信小程序的开发更简单。
8.1.1 注册Bmob账号
首先,登录Bmob 后端云官网地址(https://www.bmobapp.com),点击右上角的注册按钮,在跳转页面填入姓名、邮箱,并设置密码,确认后到邮箱激活Bmob账户,即可拥有Bmob账号。
8.1.2 创建应用
第一步,点击左边的“应用”点击顶部的“+创建应用”,填写创建信息
8.1.3 配置小程序密钥
8.1.4 获取微信小程序服务器域名和“应用密钥”
单击进入后台,选择应用项目,单击“设置”→“应用密钥”选项,可以直接获取应用项目的Application ID和SecretKey(在小程序开发中需要使用)
8.1.5 小程序中配置“安全域名”
8.1.6 下载及安装 Bmob SDK
首先,登录https://github.com/bmob/bmob-WeApp-sdk下载Bmod SDK
第一步,bmob-WeApp-sdk下载Bmod SDK,解压下载后的SDK,把bmob. js和underscore. js文件放到相应的位置。例如,要放到小程序的utils目录中,则在其他需要使用的页面添加以下代码:
var Bmob=require('./utils/bmob')
第二步,在小程序项目中的app. js中加入下面两行代码进行全局初始化:
Bomb.initialize("你的 Application ID","你的 REST API Key")
8.2 数据的增,删,改,查
为了便于在Bmob中实现数据的增加、删除、修改、查询,我们在新建的应用中新增“test”表,并在表中添加id(编号)、title(标题)、content(内容)、image(图像)字段
8.2.1 创建表及字段
在“ul”表中添加id、title、content、image列,Bmob提供Number、String、Boolean、Date、File、Geopoint、Array、Object、Pointer、Relation共10种字段类型
创建列
8.2.2 添加一条记录
代码如下:
//wxml
<button type="primary" bindtap='add'>添加记录</button>
//js
var Bmob =require('../../utils/bmob.js');
Page({
data:{
},
add:function(){
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('添加失败');
}
});
},
})
添加成功后,后台效果
8.2.3 获取一条记录
//wxml
<button type="primary" bindtap='toget'>获取记录</button>
//js
var Bmob =require('../../utils/bmob.js');
page({
toget:function(){
var Test = Bmob.Object.extend("tests");
var query = new Bmob.Query(Test);
query.get("7dd81e2596",{
success:function(result){
console.log("该记录的标题为" + result.get("title"));
console.log("该记录的内容为" + result.get("content"));
},
error:function(result,error){
console.log("查询失败");
}
})
}
})
从数据库返回的数据:
8.2.4 修改一条记录
//wxml
<button type="primary" bindtap='tochange'>修改一条记录</button>
//修改数据
var Bmob =require('../../utils/bmob.js');
page({
tochange:function(){
var Test = Bmob.Object.extend("tests");
var change = new Bmob.Query(Test);
change.get("7dd81e2596",{
success:function(result){
result.set("title","WXSS");
result.set("content","小李");
result.save();
console.log("修改成功");
console.log("该记录标题为" + result.get("title"));
console.log("该记录内容为" + result.get("content"));
},
error:function(){
console.log("修改失败")
}
})
}
})
8.2.5 删除一条记录
//wxml
<button type="primary" bindtap='todel'>删除一条记录</button>
//js
page({
//删除数据
todel:function(){
var Text = Bmob.Object.extend("tests");
var del = new Bmob.Query(Text);
del.get("19ac9ed7bd",{
success:function(Object){
Object.destroy({
success:function(deleteObject){
console.log("删除记录成功")
},
error:function(Object,error){
console.log("删除记录失败")
}
});
},
error:function(Object,error){
console.log("删除失败")
}
})
}
})
8.3 上传图片
8.3.1 上传一张图片并显示
//html
<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 temFilePaths = res.temFilePaths;
if(temFilePaths.length > 0){
var newDate = new Date();
var newDateStr = newDate.toLocaleString();
var tempFilePath = [tempFilePaths[0]];
var extension = /\.([^.]*)$/.exec(tempFilePath[0]);
if(extension){
extension = extension[1].toLowerCase();
}
var name = newDatestr + " . " + extension;
var file = new Bmob.file(name,tempFilePaths);
file.save().then(function(res){
console.log(res.url());
var url = res.url();
that.setData({
url:url
})
},function(error){
console.log(error);
})
}
}
})
}
8.3.2 上传多张图片并显示
<button type="primary" bind:tap="uppic"> 上传多张图片</button>
<block wx:for="{{list}}" wx:key="this">
<image src="{{item.url}}"/>
</block>
uppic:function(){
var that = this;
wx.chooseImage({
count: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 imgLenght = tempFilePaths.length;
if(imgLenght >0){
var newDate = new Date();
var newDatestr = newDate.toLocaleString();
var j=0;
for(var i = 0; i<imgLenght;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)
j++;
console.log(j,imgLenght);
if(imgLenght == j){
console.log(imgLenght,urlArr);
showPic(urlArr,that)//显示图片
}
},function(error){
console.log(error)
})
}
}
}
})
}