开发实战分享 小程序扫码获取图书信息(内附详细教程),2024年最新你有过迷茫吗

122 阅读6分钟

1.安装Node.js准备环境

安装nodejs,准备好环境,这一步就不细说了,没有安装的可以自行百度,不知道有没有安装的可以输入 node -v 查看一下。

2.在cmd打开云函数目录中,安装依赖

输入命令:

npm install --production
复制代码

依赖安装成功之后,文件里面多会出现 package-lock.json这个文件:

三、编写云函数代码

1.在云函数中用获取到的ISBN传参

云函数API:
developers.weixin.qq.com/miniprogram…

通过看文档可以学会,在云函数里,我们可以通过传递一份data来获取这里面的数据,然后再通过event来拿到对应的数据:

复制这个api里面的方法:

打开实战一里面写的小程序端的扫码的js界面,把这个方法放在 success里面。 要调用的云函数的名称 name要改成成实战二教程里面建立的云函数bookinfo

传递的参数是 isbn,结果是扫码得到的result

2.编写用户端(小程序端代码)

result的结果打印出来,ok,用户端(小程序端)代码写好了:

用户端(小程序端)代码写完了,就这些:

// pages/scanCode/scanCode.js
Page({

  /**
   * 页面的初始数据
   */
  data: {

  },

scanCode: function(event) {
    console.log(1)
    // 允许从相机和相册扫码
    wx.scanCode({
      onlyFromCamera: true,
      scanType: ['barCode'],
      success: res => {
        console.log(res.result)

        //
        wx.cloud.callFunction({
          // 要调用的云函数名称
          name: 'bookinfo',
          // 传递给云函数的参数
          data: {
            isbn: res.result
          },
          success: res => {
            console.log(res)
         
          },
          fail: err => {
            console.error(res)
          }
        })
      },
      fail: err => {
        console.log(err);
      }
    })
  }

})
复制代码

3.编写云函数端代码

打开 bookinfo里面的 index.js,将 event结果打印出来,请求云函数,将云函数之中的 isbn返回回来:

// 云函数入口文件
// const cloud = require('wx-server-sdk')
// cloud.init()

// 云函数入口函数
//var rp = require('request-promise')
exports.main = async (event, context) => {
 console.logI(event);
return event.isbn 
  // var res = rp('https://api.douban.com/v2/book/isbn/' + event.isbn).then(html => {
  //   return html;
  // }).catch(err => {
  //   console.log(err)
  // })
  //return res
  // const wxContext = cloud.getWXContext()
  // return {
  //   event,
  //   openid: wxContext.OPENID,
  //   appid: wxContext.APPID,
  //   unionid: wxContext.UNIONID,
  // }
}
复制代码

上传并且部署云函数:

测试一下,云函数调用成功,返回的结果(控制台打印)是isbn:

四、调用豆瓣API获取具体数据

在网上找了一下,找到了一个可以用的豆瓣API:
api.douban.com/v2/book/isb…

打开云函数文件夹,index.js里面编写代码,引用request promise:

var rp = require('request-promise')
复制代码

自定义的isbn,使用一个+号来连接,在传递一个catch来处理错误情况:

var res = rp(
 'https://api.douban.com/v2/book/isbn/'+event.isbn).then(html=>{
return html;}).catch(err=>{
console.log(err)})
复制代码

returnresres就是对应的html,将html传给用户端:

上传云函数:

继续测试一下,拿到这个条形码的信息了(书本的信息):

对于这些信息,进一步处理,拿到自己想要的信息。

打开小程序端scanCode.js:

  //进一步的处理方法        

  var bookString=res.result;        

  console.log(JSON.parse(bookString))
复制代码

看到了整本图书上面的所有信息,修改这些信息,存入云数据库之中即可。

五、将获取到的API数据存入云数据库里面

1.初始化

使用数据库的时候,首先要进行初始化:

云开发数据库文档:
developers.weixin.qq.com/miniprogram…

打开云开发控制台创建一个集合books:

打开小程序端js,初始化数据库:

 //云数据库初始化         

 const db = wx.cloud.database({});         

 const book = db.collection('books');
复制代码

2.添加数据

js代码流程:

// pages/scanCode/scanCode.js

Page({
  data: {
  },
  scanCode: function (event) {
console.log(1)
// 允许从相机和相册扫码
wx.scanCode({
  onlyFromCamera: true,
  scanType: 'barCode',
  success: res => {
console.log(res.result)
wx.cloud.callFunction({
  // 要调用的云函数名称
  name: 'bookinfo',
  // 传递给云函数的参数
  data: {
    isbn: res.result
  },
  success: res => {
    //  console.log(res)
    //进一步的处理
    var bookString = res.result;
    console.log(JSON.parse(bookString))
    //云数据库初始化
    const db = wx.cloud.database({});
    const book = db.collection('books')
    db.collection('books').add({
      // data 字段表示需新增的 JSON 数据
      data: JSON.parse(bookString)
    }).then(res => {
      console.log(res)
    }).catch(err => {
      console.log(err)
    })
  },
  fail: err => {
    console.error(res)
  }
})

  },
  fail: err => {
console.log(err);
  }
})
  }
})
复制代码

六、云数据库读取的数据显示在小程序端列表里

1.获取res.data

参考的读取api,请点击:
developers.weixin.qq.com/miniprogram…

初始化实例和book方法:

  //云数据库初始化    

  const db = wx.cloud.database({});    

  const book = db.collection('books')
复制代码

复制API这段代码获取多个记录的数据的方法,放在项目到onload方法之中:

打印在控制台:

2.设置界面相关数据

拿到res.data之后,要赋值给page实例里面的data,所以在data里面设置一个默认的空数组:

创建一个变量来保存页面page示例中的this,方便后续使用,也可以使用箭头函数来打印一下this,看是不是page示例:

const db = wx.cloud.database({});

const cont = db.collection('books');

Page({

  data: {

book\_list:[]

  },

  onLoad: function(options) {

   // 创建一个变量来保存页面page示例中的this, 方便后续使用

var _this=this;

db.collection('books').get({

  success: res =>{

 console.log(res.data);

 console.log(this);

        } 

    })

  },

})
复制代码

直接使用this来设置data:

3.显示和布局

使用组件库引入,可以省略自己写很多代码的样式,简单方便,当然也可以自己写:youzan.github.io/vant-weapp/…
因为数据不止一条,循环,所以要用到小程序框架的列表渲染:
developers.weixin.qq.com/miniprogram…

写好之后 wxml如下:

<text>私家书柜</text>

<view wx:for="{{book\\\_list}}">

  <van-card num="2" price="2.00" desc="描述信息" title="商品标题" />

</view>
复制代码

4.小程序wxml界面(主要demo)

wxml:

<view wx:for="{{book\\\_list}}">

  <van-card num="2" 

  price="{{item.price}}" 

  desc="{{item.author}}" 

  title="{{item.title}}"  

  thumb="{{item.image }}" />

</view>
复制代码

js:

const db = wx.cloud.database({});

const cont = db.collection('books');

Page({

  data: {




还有兄弟不知道网络安全面试可以提前刷题吗?费时一周整理的160+网络安全面试题,金九银十,做网络安全面试里的显眼包!


王岚嵚工程师面试题(附答案),只能帮兄弟们到这儿了!如果你能答对70%,找一个安全工作,问题不大。


对于有1-3年工作经验,想要跳槽的朋友来说,也是很好的温习资料!


【完整版领取方式在文末!!】


***93道网络安全面试题***


![](https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/a95b3a1a6ecc4519bc7bfed08955a521~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3MDgwNDUxMTkwMTI=:q75.awebp?rk3s=f64ab15b&x-expires=1771512011&x-signature=HpVSbU%2BS9WjYmRPl%2BkfAkfJInNM%3D)








![](https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/6854f810c5d54ce0bd8aff002a7c7e9e~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3MDgwNDUxMTkwMTI=:q75.awebp?rk3s=f64ab15b&x-expires=1771512011&x-signature=Y9Frp1CfLk%2BvwFkh0QCdr%2BXfyDQ%3D)





![](https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/4ce0f529563347ccb7d12ea58bcb9185~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3MDgwNDUxMTkwMTI=:q75.awebp?rk3s=f64ab15b&x-expires=1771512011&x-signature=U8h%2FgC7D367HzFl3xSMwU%2FvqT50%3D)





内容实在太多,不一一截图了


### 黑客学习资源推荐


最后给大家分享一份全套的网络安全学习资料,给那些想学习 网络安全的小伙伴们一点帮助!


对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。

#### 1️⃣零基础入门


##### ① 学习路线


对于从来没有接触过网络安全的同学,我们帮你准备了详细的**学习成长路线图**。可以说是**最科学最系统的学习路线**,大家跟着这个大的方向学习准没问题。


![image](https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/7fae376eaa7748ef9ecc44ea3983e3b8~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3MDgwNDUxMTkwMTI=:q75.awebp?rk3s=f64ab15b&x-expires=1771512011&x-signature=vTta5dt7CVu3343en1Z3Bzrw3w0%3D)


##### ② 路线对应学习视频


同时每个成长路线对应的板块都有配套的视频提供:


![image-20231025112050764](https://p9-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/de7fdf1778a24de99e5a6002ebd2a038~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3MDgwNDUxMTkwMTI=:q75.awebp?rk3s=f64ab15b&x-expires=1771512011&x-signature=MveXNzSfdycYl%2BagyC19V5bNIMg%3D)
详情docs.qq.com/doc/DSlhRRFFyU2pVZGhS