#小程序云开发挑战赛#-实验室管理小程序-Rick&Morty
预览链接
data:image/s3,"s3://crabby-images/cf14a/cf14abf6d194512ac5db0b5e11d812504060acb4" alt=""
原文地址
https://wiki.lifeisgg.online/archives/MyProject-AttendanceMiniprogram/
应用场景
在如今物联网和移动端越来越成熟的形势下,"实验室管理小程序”是一款结合管理实验室出入,记录出入日志,活跃度查看的小程序。用户出入实验室时,与线下的指纹人脸识别等硬件结合,能随时掌握自己出入实验室日志,时长,进入申请等。而管理员可以随时查看管理实验室情况,实验室成员管理,实验室开放关闭等。通过硬件和移动端小程序的结合,能做到高效,透明,规范化实验室管理。
目标用户
高校或其它有实验室机构的组织
实现思路
- 使用云开发构建项目,部署了云函数来获取用户openid,发送实验室进出的服务消息,以及调用腾讯云的云短信服务
- 前端方面,使用了colorUi作为css组件库,搭配uView组件库完成组件开发和页面开发
- 后台方面,将主要业务增删查改使用云开发的数据库存储,部分业务放到自己搭建的后台
- 硬件方面:指纹识别和人脸识别目前正在测试中,所以小程序端只是模拟进出实验室
架构图
功能代码展示
Github:https://github.com/LifeAlsoIsGG/MyProject-AttendanceMiniprogram-2.0
云函数
获取用户openid
// 云函数模板
// 部署:在 cloud-functions/login 文件夹右击选择 “上传并部署”
const cloud = require('wx-server-sdk')
// 初始化 cloud
cloud.init({
// API 调用都保持和云函数当前所在环境一致
env: cloud.DYNAMIC_CURRENT_ENV
})
/**
* 这个示例将经自动鉴权过的小程序用户 openid 返回给小程序端
*
* event 参数包含小程序端调用传入的 data
*
*/
exports.main = (event, context) => {
console.log(event)
console.log(context)
// 可执行其他自定义逻辑
// console.log 的内容可以在云开发云函数调用日志查看
// 获取 WX Context (微信调用上下文),包括 OPENID、APPID、及 UNIONID(需满足 UNIONID 获取条件)等信息
const wxContext = cloud.getWXContext()
return {
event,
openid: wxContext.OPENID,
appid: wxContext.APPID,
unionid: wxContext.UNIONID,
env: wxContext.ENV,
}
}
订阅消息/服务消息
const cloud = require('wx-server-sdk')
cloud.init()
// 云函数入口函数
exports.main = async (event, context) => {
// var formId = event.formId
// console.log('formId=' + formId)
try {
const sendResult = await cloud.openapi.subscribeMessage.send({
touser: cloud.getWXContext().OPENID,
templateId: 'demo',
page: 'pages/home/home',
data: {
thing1: {
value: event.info.user,
},
phrase2: {
value: event.info.status,
},
time3: {
value: event.info.date,
},
thing4: {
value: event.info.rname,
},
thing5: {
value: event.info.address,
}
// event.info.title
// event.info.date
// event.info.address
}
})
console.log(sendResult)
return "sendResult"
} catch (err) {
console.log(err)
return err
}
}
调用腾讯云云短信服务
// 云函数入口文件
cloud.init()
const sms = require("qcloudsms_js")
// 云函数入口函数
exports.main = async (event, context) => new Promise((resolve,reject)=> {
let SmsSdkAppid = 'demo'
let appkey="demo"
let templateId="demo"
let smsSign="实验室出入管理小程序"
let sender=sms(SmsSdkAppid,appkey).SmsSingleSender()
sender.sendWithParam(
86,
event.phone,
templateId,
[event.code],
smsSign,
'','',
(err,res,resData)=>{
if(err){
reject({err})
}else{
resolve({
res:res.req,
resData
})
}
}
)
})
效果截图
data:image/s3,"s3://crabby-images/077d4/077d49ec0e3dc5fe22e2766532cda72152658790" alt=""
data:image/s3,"s3://crabby-images/f71e0/f71e072b5aa45db44c19c56a58b8412946314f0a" alt=""
data:image/s3,"s3://crabby-images/f9b37/f9b37d7c46790f170b563c310b1082684d9e23b2" alt=""
data:image/s3,"s3://crabby-images/3e11c/3e11cf578cfec9b26cac725e7055a8d793b65ef4" alt=""
data:image/s3,"s3://crabby-images/351e7/351e77adf1edac1ae365b9733c649b366d27651b" alt=""
data:image/s3,"s3://crabby-images/42ca3/42ca36fd8c9c36ca0ddcc78961c083f685622518" alt=""
data:image/s3,"s3://crabby-images/79a82/79a8283ec7f355700c5165004a9ac13c048bc72c" alt=""
data:image/s3,"s3://crabby-images/5e486/5e486fc9a578a4878fcaa3920b81c637130077e0" alt=""
data:image/s3,"s3://crabby-images/9633e/9633e8f81bf8e89d41805410f22acb6b5aaacb1d" alt=""
data:image/s3,"s3://crabby-images/1cbd4/1cbd420995b5bff3f12811b96e5dbc47c8327497" alt=""
data:image/s3,"s3://crabby-images/13be8/13be82511e7a5e9e5320d1fa51b0f0b5f10a7ce3" alt=""
data:image/s3,"s3://crabby-images/fb0e7/fb0e75b457572c22f76c623a46113cf8619eb4eb" alt=""
data:image/s3,"s3://crabby-images/cd6ec/cd6ecaa711fb9fe9ec77e4c406d420d65d4baf84" alt=""
data:image/s3,"s3://crabby-images/87a3c/87a3c51b39d29d12db63fcb77bc232fe4124d231" alt=""
data:image/s3,"s3://crabby-images/1fb6f/1fb6f9b9d27cd79105d2f693f7f6dc4b7343d4f9" alt=""