目录

第八章小程序后端开发

第八章小程序后端开发

8.1 比目后端云简介

一个完整的小程序系统,不但需要前端的展现,而且需要后端 的支撑,以提供数据服务。也就是说,开发一个真正完整的小程序应用,需要前后端的相互配合。小程序与远程服务器之间通过HTTPS传输协议进行数据交换

小程序开发结构

https://i-blog.csdnimg.cn/blog_migrate/afac2b011180004f1c3f30a84e6eed7d.png

除了自己搭建服务端以外,还可以利用一些网络公司提供的云服务来进行小程序后端的相应开发。本章主要讲解利用比目网络科技有限公司提供的Bmob后端云进行小程序后端开发。

Bmob后端云专注于为移动应用提供一整套后端云服务,能帮助开发者免去几乎所有服务器端的编码工作,大幅度降低开发成本和开发时间。

Bmob提供了小程序软件开发工具包(Software Development Kit, SDK),让用户拥有强大的后端服务。嵌入Bmob小程序SDK后,开发工程师可以更加专注于编写前端代码和优化良好的用户体验,而不必担心后端的基础设施。

Bmob提供了成熟的WebSocket信道服务,降低了开发者使用WebSocket通信的门槛。同时也满足了小程序需要HTTPS与服务端通信的需求。

Bmob还提供了短信验证功能,只需几行简单的代码,即可实现微信小程序的用户登录、富媒体文件上传、发送短信通知和微信支付等功能。

总之,Bmob让微信小程序的开发更简单

8.1.4  获取“应用密钥”

https://i-blog.csdnimg.cn/blog_migrate/a9b842873117c57ddc1bbab599c03bc1.png

8.1.6  下载及安装Bmob SDK

**登录

下载Bmod SDK,**

https://i-blog.csdnimg.cn/blog_migrate/6482b856ee11fedbd8e4686c01f848b4.png **解压下载后的SDK,

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

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

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

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

8.2  数据的增、删、改、查

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

8.2.1   创建表及字段

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

https://i-blog.csdnimg.cn/blog_migrate/ff97cdb3b4b40f76a258d89f10327d61.png

8.2.2   添加一条记录

添加一条记录用来实现把从前端获取的数据添加到服务端数据表中,主要用Bmob提供的SDK对象实现

在index.wxml中输入代码:

<button type="primary" bindtap='add'>添加记录</button>

在index.js中输入代码:

var Bmob =require('../../utils/bmob');
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('添加失败');
}
});
},
})

执行效果:

https://i-blog.csdnimg.cn/blog_migrate/e8109bc8be7ae805b293c02b16ae95b2.png

https://i-blog.csdnimg.cn/blog_migrate/c3777db63d4e28464f72f8d26485828a.png

8.2.3   获取一条记录

获取一条记录是指从数据表中查询一条记录,主要根据 objectID 值来直接获取单条数据对象

在index.wxml中输入代码:

<button type="primary" bindtap='query'>获取记录</button>

在index.js中输入代码:

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

执行效果:

https://i-blog.csdnimg.cn/blog_migrate/d025ddb685896643bf1cbfc051f26ba8.png

8.2.4  修改一条记录

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

在index.wxml中输入代码:

<button type="primary" bindtap='modi'>修改记录</button>

在index.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("4f84ff6923",{
  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("修改失败")
  }
  });
}
}
)

执行效果:

https://i-blog.csdnimg.cn/blog_migrate/5d3c9d968740e66aedd36a1e704d8f79.png

8.2.5   删除一条记录

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

在index.wxml中输入代码:

<button type="primary" bindtap='del'>删除记录</button>

在index.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("4f84ff6923",{
  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("修改失败")
  },
});
},
})

执行效果:

https://i-blog.csdnimg.cn/blog_migrate/e45fe70b2402e5f7ea411f31d2ebd3b2.png

https://i-blog.csdnimg.cn/blog_migrate/03a025ffe22b0588509e55585ce8f60b.png

8.2.6   查询所有数据

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

在index.wxml中输入代码:

<button type="primary" bindtap='queryall'>获取所有数据记录</button>

在index.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);
}
  }, 
  )}
})

执行效果:

https://i-blog.csdnimg.cn/blog_migrate/e706d0dd003cfa7bafb8d6b89d7a1672.png

https://i-blog.csdnimg.cn/blog_migrate/8c25ddf9a94879183c90f5f74f88324b.png

8.2.7   条件查询

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

在index.wxml中输入代码:

<button type="primary" bindtap='wherequery'>条件查询</button>

在index.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);
  }
});
}
})

执行效果:

https://i-blog.csdnimg.cn/blog_migrate/abc7a332bb2a907baf927f22acd83bd4.png https://i-blog.csdnimg.cn/blog_migrate/664eeb28059b65c2566f8744a0d5c30c.png

8.2.8  分页查询

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

query.limit(10);

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

query.skip(10);

8.3   上传图片

8.3.1  上传一张图片并显示效果

Bmob提供了文件后端保存功能。利用这一功能,我们可以把本地文件上传到Bmob后台,并按上传日期为文件命名

在index.wxml中输入代码:

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

在index.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("嘟嘟嘟"+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);
            }
          )
        }
      }
    })
  },
})
 

执行效果:

https://i-blog.csdnimg.cn/blog_migrate/ce04a8d358ab94f900ab07df0abc9d5f.png

8.3.2   上传多张图片并显示效果

Bmob支持一次上传多张图片,并将图片保存到素材库中

在index.wxml中输入代码:

<button type="primary" bindtap="uppic">上传多张照片</button>
<block wx:for="{{list}}" wx:key="this">
  <image src="{{url}}"></image>
</block>

在index.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)
        j++;
        console.log(j.imgLength);
        if(imgLength==j){
        console.log(imgLength,urlArr);
        //如果担心就可以去掉这几行注释
        showPic(urlArr,that)//显示图片
      }
      },function(error){
        console.log(error);
      })
    }
  }
}
});
}
})

执行效果:

https://i-blog.csdnimg.cn/blog_migrate/808d9cc4b7e913061c6b2daeae9299f4.png