目录
用途说明
组成部分
目录结构
原理时序
云端一体组件介绍
验证码配置(可选):
普通验证码组件
公共模块
云函数公用模块
项目实战
创建云函数
创建注册页
创建云函数
关联公用模块 uni-captcha
刷新验证码
自定义实现 验证码
获取验证码
刷新验证码
校验验证码
下载地址:uni-captcha - DCloud 插件市场
GitCode 仓库:uniCaptcha: 基于uniCloud的验证码模块
主要起到人机校验或其他限制调用的作用,如:
常见的业务场景有:
uni-captcha
,集成获取、刷新、校验验证码uni-captcha-co
,集成获取验证码的apiuni-captcha
和uni-popup-captcha
,集成创建、刷新、显示验证码scene
,表示应用场景,用于防止不同功能的验证码混用,如:login
、pay
opendb-verify-codes
中创建状态为待验证的验证码记录(作废同一个设备id和场景值的旧验证码记录),并返回格式为base64的图形验证码资源数据。提示:这里的数据表,状态字段名:state
用0
表示待验证,用2
表示已作废。verify
方法详情,也可以直接查库校验。以上即完整的流程。 如果在前端表单页面中,使用本插件封装好的云端一体组件,并配置组件的属性场景值scene
,即等价于如上步骤1-3;
本插件已集成使用示例,使用HBuilderX导入示例项目体验;另外你也可以参考插件在uni-starter中的应用
内置调用uni-captcha-co
云对象集成创建/刷新验证码,组件支持双向数据绑定。
参数说明:
字段 | 类型 | 默认值 | 说明 |
---|---|---|---|
width | Number | 150 | 图片宽度 |
height | Number | 40 | 图片高度 |
background | String | #FFFAE8 | 验证码背景色,设置空字符'' 不使用背景颜色 |
size | Number | 4 | 验证码长度,最多 6 个字符 |
noise | Number | 4 | 验证码干扰线条数 |
color | Boolean | false | 字体是否使用随机颜色,当设置background 后恒为true |
fontSize | Number | 40 | 字体大小 |
ignoreChars | String | 忽略哪些字符 | |
mathExpr | Boolean | false | 是否使用数学表达式 |
mathMin | Number | 1 | 表达式所使用的最小数字 |
mathMax | Number | 9 | 表达式所使用的最大数字 |
mathOperator | String | 表达式所使用的运算符,支持 + 、- 。不传则随机使用 |
|
expiresDate | Number | 180 | 验证码过期时间(s) |
scene | Object | 根据场景值配置(版本号:0.6.0+ 支持) |
组件名:uni-captcha
组件遵从easycom组件规范
使用示例:
Props:
字段 | 类型 | 必填 | 默认值 | 说明 |
---|---|---|---|---|
scene | String | 是 | - | 使用场景值,用于防止不同功能的验证码混用,如:login 、pay |
value/v-model | String | - | - | 验证码的值 |
uni-captcha
和uni-popup-captcha
,已经集成公共模块的获取验证码create
和刷新验证码refresh
接口。云函数支持公共模块。多个云函数的共享部分,可以抽离为公共模块,然后被多个云函数引用。
版本要求:HBuilderX 2.6.6+
以下面的目录结构为例,介绍一下如何使用。
新建并引入公用模块
cloudfunctions
目录下创建common
目录common
目录右键创建公用模块目录(本例中为hello-common
,见下方示例图),会自动创建入口index.js
文件和package.json
,不要修改此package.json的name字段hello-common
右键上传公用模块管理公共模块依赖
,添加依赖的公共模块公共模块依赖其他公共模块同理
注意事项
common
目录下的公用模块目录(本例中为hello-common
)右键选择更新依赖本模块的云函数
npm install
创建的软链接失效,如果遇到这种情况请删除node_modules
和package-lock.json
重新npm install
使用公用模块
仍以上面的目录为例,在公用模块内exports
,在云函数内require
即可。示例代码如下:
// common/hello-common/index.js
function getVersion() {
return '0.0.1'
}
module.exports = {
getVersion,
secret: 'your secret'
}
// use-common/index.js
'use strict';
const {
secret,
getVersion
} = require('hello-common')
exports.main = async (event, context) => {
let version = getVersion()
return {
secret,
version
}
}
我们来创建uni-captcha云函数,如下图右击cloudfunctions,选择新建云函数/云对象。
弹出如下图后,我们选择uni-captcha即可,点击确认。 、
然后cloudfunctions中,则会生成common/uni-captcha和uni-captcha-co两个模块。
云函数都创建成功后,我们实现一个简单的登录页面,如下图:
博主 from表单使用了 uview 可以换成 uni-ui
uView - 多平台快速开发的UI框架 - uni-app UI框架
用户注册
/*
此时我们创建一个云函数,用于对表单中输入的验证码,进行校验其是否正确。还是在cloudfunctions上右击,选择“新建云函数/云对象”,如下图:
点击创建后,cloudfunctions中会生成云函数。如下图:
此时可以在index.js中添加图形验证码校验功能,返回校验结果。代码如下:
'use strict';
//导入验证码公共模块
const uniCaptcha = require('uni-captcha')
const db = uniCloud.database();
exports.main = async (event) => {
const { Phone, Password, scene, captcha } = event;
try {
// 校验验证码
let res = await uniCaptcha.verify({ scene, captcha })
// 验证通过
if (res.code == 0) {
// 校验是否已经注册
const userExists = await db.collection("User").where({ Phone: Phone }).get();
if (userExists.data.length !== 0) {
return {
code: 1,
message: "该账号已注册",
};
}
// 添加用户
await db.collection("User").add({
time: Date.now(),
Phone: Phone,
Password: Password,
});
return {
code: 0,
message: "注册成功"
};
} else {
// 验证失败
return {
code: -1,
message: res.errMsg || res.message || "验证码异常",
};
}
} catch (error) {
// 出现异常
console.error('添加用户失败:', error);
return {
code: -1,
message: "注册失败,请稍后重试",
};
}
};
在云函数上鼠标右击,选择”管理公共模块或扩展库依赖“
选择”uni-captcha“公共模板,点击确认。
另外,我们发现如果验证码错误后,显示的验证码不会自动刷新。由于这里我们使用的是uni-app的扩展UI组件,功能不好升级维护,如果觉得此组件不好用,也可以自己使用uni-captcha-co获取验证进行个性化操作。
这里主要是为了演示,就先在原基本上完成刷新功能。打开uni_modules目录,找到uni-captcha组件,再打开components目录中的uni-captcha,我们来看下内部是如何实现的。
如上图所示,我们发现应用场景发生改变后,验证码会重新获取。所以上文中这样做的
加入随机数让其变化
用于新的验证码记录(使用云端一体组件的用户可以忽略)
//引入公共模块
const uniCaptcha = require('uni-captcha')
module.exports = {
async createCaptcha({scene}) {
return await uniCaptcha.create({
scene,
width:100,
height:44
});
}
}
参数说明
字段 | 类型 | 必填 | 默认值 | 说明 |
---|---|---|---|---|
scene | String | 是 | - | 使用场景值,用于防止不同功能的验证码混用,如:login 、pay |
deviceId | String | - | - | 设备 id,如果不传,将自动从 uniCloud 上下文获取 |
uniPlatform | String | - | - | uni-app 运行平台 |
width | Number | - | 150 | 图片宽度 |
height | Number | - | 40 | 图片高度 |
background | String | - | #FFFAE8 | 验证码背景色,设置空字符'' 不使用背景颜色 |
size | Number | - | 4 | 验证码长度,最多 6 个字符 |
noise | Number | - | 4 | 验证码干扰线条数 |
color | Boolean | - | false | 字体是否使用随机颜色,当设置background 后恒为true |
fontSize | Number | - | 40 | 字体大小 |
ignoreChars | String | - | '' | 忽略哪些字符 |
mathExpr | Boolean | - | false | 是否使用数学表达式 |
mathMin | Number | - | 1 | 表达式所使用的最小数字 |
mathMax | Number | - | 9 | 表达式所使用的最大数字 |
mathOperator | String | - | '' | 表达式所使用的运算符,支持 + 、- 。不传则随机使用 |
expiresDate | Number | - | 180 | 验证码过期时间(s) |
注意:
uni-captcha 0.3.0
起,支持在unicloud配置中心uni-config-center
->uni-captcha
->config.json
中配置参数默认值.ttf
且包含 ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+-
字符响应参数
字段 | 类型 | 说明 |
---|---|---|
errCode | Number | 错误码,0 表示成功 |
errMsg | String | 详细信息 |
captchaBase64 | String | 验证码:base64 格式 |
作废相同设备id和场景值的验证码记录,并创建新的验证码记录(使用云端一体组件的用户可以忽略)
//引入公共模块
const uniCaptcha = require('uni-captcha')
const db = uniCloud.database();
const verifyCodes = db.collection('opendb-verify-codes')
module.exports = {
async refreshCaptcha({scene}) {
let res = await verifyCodes.where({scene,deviceId,state:0}).limit(1).get()
if(res.data.length){
return await uniCaptcha.refresh({
scene,
width:100,
height:44
});
}else{
return {
errCode: "uni-captcha-refresh-fail",
errMsg: '未找到相同设备id和场景值的有效验证码记录'
}
}
}
}
参数说明
字段 | 类型 | 必填 | 默认值 | 说明 |
---|---|---|---|---|
scene | String | 是 | - | 类型,用于防止不同功能的验证码混用 |
deviceId | String | - | - | 设备 id,如果不传,将自动从 uniCloud 上下文获取 |
响应参数
字段 | 类型 | 说明 |
---|---|---|
errCode | Number | 错误码,0 表示成功 |
errMsg | String | 详细信息 |
captchaBase64 | String | 验证码:base64 格式 |
注意:
用于验证用户输入的验证码是否正确
const uniCaptcha = require('uni-captcha')
module.exports = {
async verify({scene,captcha}) {
let res = await uniCaptcha.verify({scene,captcha})
if(res.code == 0){
//...这里写你的业务逻辑
}else{
return res
}
}
}
参数说明
字段 | 类型 | 必填 | 默认值 | 说明 |
---|---|---|---|---|
scene | String | 是 | - | 类型,用于防止不同功能的验证码混用 |
captcha | String | 是 | - | 验证码 |
deviceId | String | - | - | 设备 id,如果不传,将自动从 uniCloud 上下文获取 |
响应参数
字段 | 类型 | 说明 |
---|---|---|
errCode | Number | 错误码,0 表示成功 |
errMsg | String | 详细信息 |
注意: