第八章总结——小程序后端开发

比目后端云简介

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

1注册Bmob账号

2.创建应用

3.配置秘钥

无需获取也可以使用该软件(因为开启密钥需要100,我们可以应用软件提供的密钥)X

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

无需开启也可以使用该软件

单击进入后台,选择应用项目,单击“设置”→“应用密钥”选项,可以直接获取应用项目的Application ID和SecretKey(在小程序开发中需要使用)

5.小程序中配置“安全域名”

登录微信公众号平台,单击“设置”→“开发设置”选项。

6.下载安装Bmob SDK

首先,登录https://github.com/bmob/bmob-WeApp-sdk下载Bmod SDK

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

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

数据的增、删、改、查

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

第一步创建表(Bmob)

第二步创建列

添加一条记录

添加一条记录主要用Bmob提供的对象来实现

/*.wxml*/
<button type="primary"bindtap="add">添加记录</button>
 
 
/*.js*/
var Bmob=require('../../utils/bmob')
Page({
  data:{
 
  },
  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("添加失败")
      }
    });
  },
})
 
获取一条记录

获取一条数据objectId值来获取单条数据对象

/*.wxml*/
<button type="primary"bindtap="query">获取记录</button>
 
 
/*.js*/
var Bmob=require('../../utils/bmob')
Page({
  data:{
 
  },
  query:function () {
    var Test=Bmob.Object.extend("test");
    var query=new Bmob.Query(Test);
    query.get("5d2a21d39d",{
      success:function (result) {
        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')
Page({
  data:{
 
  },
  modi:function () {
    var Test=Bmob.Object.extend("test");
    var query=new Bmob.Query(Test);
    query.get("5d73a8aff6",{
      success:function (result) {
        result.set('title','WXSS');
        result.set('content',"Wenxin Style Class");
        result.save();
        console.log("修改成功");
        console.log("该记录标题修改为"+result.get("title"));
        console.log("该记录内容修改为"+result.get("content"));
      },
      error:function (object,error) {
        console.log("修改失败");
      }
    });
  },
})
删除一条记录

删除一条数据可以用destroy方法

/*.wxml*/
<button type="primary"bindtap="del">删除记录</button>
 
/*.js*/
var Bmob=require('../../utils/bmob')
Page({
  data:{
 
  },
del:function () {
    var Test=Bmob.Object.extend("test");
    var query=new Bmob.Query(Test);
    query.get("e99ff4a489",{
      success:function (object) {
        object.destroy({
          success:function (deleteObject) {
            console.log("删除记录成功");
          },
          error:function (object,error) {
            console.log("删除记录失败");
          }
        });
      },
      error:function (object,error) {
        console.log("修改失败");
      }
    });
  },
})
 查询所有数据

为了获取某个数据表中的所有数据,可以用Query对象实现

/*.wxml*/
<button type="primary"bindtap="queryall">获取所有数据记录</button>
 
 
/*.js*/
var Bmob=require('../../utils/bmob')
Page({
  data:{
 
  },
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('content'));
        }
      },
      error:function (error) {
        console.log("查询失败:"+error.code+""+error.message);
      }
    });
  },
})
条件查询

方法主要有:等于(equalTo)、不等于(notEqualTo)、大于(greaterThan)、大于等于(greaterThanOrEqualTo)、小于(lessThan)、小于等于(lessThanOrEqualTo)

/*.wxml*/
<button type="primary"bindtap="wherequery">条件查询</button>
 
 
 
/*.js*/
var Bmob=require('../../utils/bmob')
Page({
  data:{
 
  },
wherequery:function () {
    var Test=Bmob.Object.extend("test");
    var query=new Bmob.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);
      }
    });
  },
})
分页查询 

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

上传图片

上传一张图片并显示

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

/*.wxml*/
<button type="primary" bindtap="upimage">上传一张图片</button>
<image src="{{url}}"></image>
 
/*.js*/
var Bmob=require('../../utils/bmob')
Page({
  data:{
 
  },
 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=newDate +"."+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);
         })
       }
     }
   })
 },
})
上传多张图片并显示

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

/*.wxml*/
<button type="primary" bindtap="uppic">上传多张图片</button>
<block wx:for="{{list}}" wx:key="this">
<image src="{{item.url}}"/>
</block>
/*.js*/
const { File } = require('../../utils/bmob.js');
var Bmob=require('../../utils/bmob')
Page({
  data:{
 
  },
 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,tempFilePaths);
         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(res.list)
           j++;
           console.log(j,imgLength);
         },function (error) {
           console.log(error);
         })
        }
       }
     }
   })
 },
})

  • 22
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
电商小程序后端开发的功能点包括但不限于以下几个方面: 1. 用户管理: 实现用户的注册、登录、个人信息管理等功能,包括用户身份验证和权限控制。 2. 商品管理: 实现商品的添加、编辑、删除、查询等功能,包括商品分类、属性、库存管理等。 3. 订单管理: 实现订单的创建、支付、取消、发货、退款等功能,包括订单状态的管理和订单与商品的关联。 4. 购物车管理: 实现购物车中商品的添加、删除、数量修改等功能,包括购物车与用户和商品的关联。 5. 支付管理: 实现与第三方支付平台的对接,处理用户支付请求,生成支付订单等。 6. 物流管理: 实现订单的物流跟踪功能,包括订单发货、物流信息查询等。 7. 评价管理: 实现用户对商品的评价功能,包括评价的提交、查看、回复等。 8. 促销管理: 实现促销活动的创建、管理、展示等功能,包括满减、折扣、优惠券等。 9. 数据统计与分析: 实现对用户、商品、订单等数据的统计和分析,提供数据报表和可视化展示。 10. 客服与反馈: 实现用户与客服的实时通讯功能,包括在线咨询、投诉建议等。 以上只是电商小程序后端开发中的一些常见功能点,具体的功能需求还会根据实际业务需求而有所差异。123 #### 引用[.reference_title] - *1* *3* [从零开始,开发一个电商微信小程序[前端+后端(c#)]](https://blog.csdn.net/weixin_42794881/article/details/109178368)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] - *2* [搭建JAVA电商平台——后端](https://blog.csdn.net/Akira_Rexlee/article/details/81144817)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值