第八章--小程序后端开发

一、比目后端云简介

1、注册Bmob账号

进入Bmob官方网站 (https://www.bmobapp.com)后,单击右上角的“注册”按钮,在跳转页面填入姓名、邮箱,并设置密码,确认后到邮箱激活Bmob账户,即可拥有Bmob账号。

2、创建应用                                                                                                                     

进入后台,单击左边的“应用”图标,会出现已经创建的应用项目列表和“创建应用”按钮。单击“创建应用”按钮,出现的对话框,填写完成应用的相关信息后,即可创建一个等待开发的应用。

3、配置小程序密钥

进人后台,选择应用项目,单击“设置”一“应用配置”选项,将小程序中的ApplD(小程序 ID)和 AppSecret (小程序密钥)填写到 Bmob 中。

4、获取微信小程序服务器域名和”应用密钥"

进入后台,选择应用项目,单击“设置”一“应用配置”选项,在该界面中可以得到“微信小程序服务器域名配置”(在小程序配置中需要使用)

进入后台,选择应用项目,单击“设置”一“应用密钥”选项,可以获取应用项目的Application ID 和 Seeret Key(在小程序开发中需要使用),如图8-6所示。
应用设置

5、小程序中配置"安全域名”

登录微信公众号平台,单击“设置”一“开发设置”选项,在服务器域名中输入以图8-5 获取的合法域名。

6、下载安装Bmod SDK

登录 GitHub - bmob/bmob-WeApp-sdk: 微信小程序SDK下载Bmod SDK,解压下载后的SDK,把bmob-min. js和underscore. js文件放到相应的位置。例如,要放到小程序的utils目录中

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

二、数据的增、删、改、查

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

1、创建表及字段

2、添加一条记录

用来实现把从前端获取的数据添加到服务端数据表中,主要用Bmob提供的SDK对象实现。示例代码如下:

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('添加失败');
}
});
},
})

 运行效果:    

 3、获取一条记录 

wxml

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

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("1a67adc746",{
success:function(result){
    //The object was retrieved successfully.
  console.log("该记录标题为"+result.get("title"));
  console.log("该记录的内容为"+result.get("content"));
  },
  error:function(result,error){
  console.log("查询失败");
}
});
}
})

运行效果  4、修改一条记录

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("51281151df",{
  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("修改失败")
  }
  });
}
}
)

运行效果                                                                                                                        

5、删除一条记录                                                                                                                            

    删除一条记录可以使用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("8ba0a7ccf6",{
  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("修改失败")
  },
});
},
})

运行效果:                                                                                                                                            

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

运行结果:

7、条件查询

Bmob中提供的查询方法主要有:等于(equalTo)、不等于(notEqualTo)、小(lessThan)小于等于(lessThanOrEqualTo)、大于(greaterThan)、大于等于(greaterThanOrEqualTo)等。
//index.wxml
<button type="primary" bindtashangp='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);
  }
});
}
})

运行效果:                                                                                                                                      8、分页查询                                                                                                                    

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

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

query.skip(10); 

三、上传图片

1、上传一张图片并显示

上传一张图片并显示

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

index.wxml代码如下:

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

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;//上传的图片的别名
          
          var file = new Bmob.File(name,tempFilePaths);
          file.save().then(
            function(res){
              
              var url=res.url();
              that.setData({ 
                url:url
              })
            },
            function(error){
              console.log(error);
            }
          )
        }
      }
    })
  },
})

运行效果:

2、上传多张图片并显示

Bmob支持一次上传多张图片,并将图片保存到素材库中。示例代码如下: 

index.wxml代码如下:

//index.wxml
<button type="primary" bind:tap="uppic">上传多张图片</button>
<block wx:for="{{list}}" wx:key="this">
<image src="{{item.url}}"></image>
</block>
 
//idnex.js
var Bmob =require('../../utils/bmob.js');
Page({
  data:{
    url:""
  },
  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 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
              })
              var list;
              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);
            })
          }
        }
      }
    })
  }
})

运行效果;                                                                                                                                         

  • 24
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值