taro小程序进入腾讯验证码

接入原因

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

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

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

  1. 在 app.config.ts 引入小程序插件。 版本有更新现在是2.1.1
bash 复制代码
 {
  "plugins": {
    "captcha": {
      "version": "2.1.1",
      "provider": "wx1fe8d9a3cb067a75"
    }
  }
}
  1. 在需要加载验证码的页面配置插件,如page/index/index.config.ts。
bash 复制代码
 {
  "usingComponents": {
    "t-captcha": "plugin://captcha/t-captcha"
  }
}
  1. 在页面调用验证码,如 page/index/index.tsx。
bash 复制代码
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 和 ticket
	    console.log(event.detail)
	    // 验证码验证完成
	    if(event.detail.ret === 0) {
	      this.setState({
	        txJiYan: event.detail
	      },()=>{
	      	// 发送短信
	        this.sendCode()
	      })
	    } else {
	      // 验证失败
	      // 请不要在验证失败中调用refresh,验证码内部会进行相应处理
	    }
	}
	render() {
		return (
			<t-captcha
	          id='captcha'
	          appId={CaptchaAppId}
	          themeColor={themeColor}
	          onVerify={this.bindverify}
	        />
		)
	}
}

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


区别一览

小程序原型

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

uni-app框架

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

Taro小程序

bash 复制代码
<t-captcha id='captcha' appId='小程序插件验证码CaptchaAppId' onVerify={handlerVerify} />
相关推荐
00后程序员张12 小时前
HTTPS单向认证、双向认证、抓包原理与反抓包策略详解
网络协议·http·ios·小程序·https·uni-app·iphone
梦梦代码精14 小时前
LikeShop按摩到家系统:2026年本地生活创业新风口,上门服务O2O源码私有化部署实战
大数据·docker·小程序·uni-app·生活·高并发·开源软件
leduo668899o15 小时前
商城小程序自由容器支持图片自适应详解:从入门到实战全攻略
小程序
这是个栗子16 小时前
【uni-app微信小程序问题解决】Uni-app 微信小程序组件不渲染
微信小程序·小程序·uni-app
万岳科技系统开发17 小时前
外卖跑腿配送开发搭建指南:从用户下单到配送完成全流程解析
大数据·前端·小程序
靠谱品牌推荐官17 小时前
【高性能工程】每秒万次物联网数据高频握手:如何设计一套抗丢包的工业级小程序后端微服务架构?
物联网·小程序·架构
靠谱品牌推荐官17 小时前
【高并发实战】如何基于缓存穿透治理机制设计一套高可用的小程序本地缓存中台架构?
缓存·小程序·架构
小羊Yveesss17 小时前
商家小程序外卖订单打印方案:云打印机对接、分单逻辑与模板配置实战
小程序·apache
爱学习 爱分享2 天前
微信小程序html 在 webview 会打开再缩放一下
微信小程序·小程序·html
梦梦代码精2 天前
深度拆解:上门按摩系统如何成为本地生活“到家时代”的新引擎?
docker·小程序·uni-app·开源·生活·开源软件