当前位置: 首页 > news >正文

taro小程序进入腾讯验证码

接入原因

昨天突然晚上有人刷我们公司的登录发送短信接口,紧急将小程序的验证码校验更新上去了

接下来就是我们的接入方法,其实很简单,不过有时候可能大家着急就没有仔细看文档,腾讯验证码文档微信小程序地址,注意这里分三种接入的前端框架,我这里就着急使用了小程序原生的接入代码,虽然看到了Taro框架的小程序接入示例

Taro 框架小程序插件接入示例

  1. 在 app.config.ts 引入小程序插件。 版本有更新现在是2.1.1
 {"plugins": {"captcha": {"version": "2.1.1","provider": "wx1fe8d9a3cb067a75"}}
}
  1. 在需要加载验证码的页面配置插件,如page/index/index.config.ts。
 {"usingComponents": {"t-captcha": "plugin://captcha/t-captcha"}
}
  1. 在页面调用验证码,如 page/index/index.tsx。
import Taro from '@tarojs/taro'export default function Index() {constructor(props) {this.bindverify = this.bindverify.bind(this)}const { page } = Taro.getCurrentInstance();const captcha = page.selectComponent && page?.selectComponent('#captcha');try {captcha?.show();} catch (error) {// 进行业务逻辑,若出现错误需重置验证码,执行以下方法captcha?.refresh();}// 验证码回调bindverify = (event) => {// 获取randstr 和 ticketconsole.log(event.detail)// 验证码验证完成if(event.detail.ret === 0) {this.setState({txJiYan: event.detail},()=>{// 发送短信this.sendCode()})} else {// 验证失败// 请不要在验证失败中调用refresh,验证码内部会进行相应处理}}render() {return (<t-captchaid='captcha'appId={CaptchaAppId}themeColor={themeColor}onVerify={this.bindverify}/>)}
}

注意一定要按照对应的小程序架构插件去对接,原因是不同架构的编译模式不一样,Taro会将app-id中的都以小写去编译,插件是拿不到值的,所以这里要用appId ,而返回的方法 都要是on开头的,所以引用的时候这里要留意


区别一览

小程序原型

<t-captchaid="captcha"app-id="小程序插件验证码CaptchaAppId"bindverify="handlerVerify"bindready="handlerReady"bindclose="handlerClose"binderror="handlerError" />

uni-app框架

<t-captchaid="captcha"app-id="小程序插件验证码CaptchaAppId"@verify="handlerVerify"@ready="handlerReady"@close="handlerClose"@error="handlerError" />

Taro小程序

<t-captcha id='captcha' appId='小程序插件验证码CaptchaAppId' onVerify={handlerVerify} />
http://www.lryc.cn/news/498233.html

相关文章:

  • 原子类相关
  • RabbitMQ 客户端 连接、发送、接收处理消息
  • Java Web 3 Axios Vue组件库
  • 双目相机的标定,视差图,深度图,点云生成思路与实现。
  • 【H2O2|全栈】MySQL的基本操作(三)
  • 2、C++命名空间
  • Elemenu-UI时间日期单个组件,限制当前日期之后的时间
  • flutter修改状态栏学习
  • 解决Unity编辑器Inspector视图中文注释乱码
  • 关于csgo的游戏作弊与封禁
  • 严格单元测试造就安全软件
  • ubuntu 根分区逻辑卷扩容
  • 如何查看电脑生产日期
  • MAC M1 mysql 8.0 如何修改root用户密码
  • 漫画之家系统:Spring Boot框架下的漫画版权保护
  • 在 MacOS 上为 LM Studio 更换镜像源
  • Nginx配置https(Ubuntu、Debian、Linux、麒麟)
  • 「Mac畅玩鸿蒙与硬件40」UI互动应用篇17 - 照片墙布局
  • VMware Workstation 安装Ubuntu 系统(图文步骤)
  • mybatis用pagehelper 然后用CountJSqlParser45,发现自己手写的mapper查询效率很慢
  • 【优选算法 二分查找】二分查找入门详解:二分查找 & 在排序数组中查找元素的第一个和最后一个位置
  • WPF编写工业相机镜头选型程序
  • 网络安全内容整理二
  • 解决git did not exit cleanly (exit code 128)问题
  • Linux入门攻坚——40、Linux集群系统入门-lvs(1)
  • momentum 和 weight_decay 的区别
  • Vue 3 + TypeScript进阶用法
  • AbutionGraph-时序向量图谱数据库-快速安装部署
  • Delphi-HTTP通讯及JSON解析
  • Postgres 如何使事务原子化?