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

uniapp 各个端接入腾讯滑动行为验证码示例

验证调起页面:

<template>
	<view class="app">
		<text>{{ obj.ret }}</text>
		<button @click="varify">验证</button>
	</view>
</template>

<script>
	export default{
		data(){
			return{
				obj: {}
			}
		},
		onLoad() {
			// #ifdef H5
			var script = document.createElement('script');
			script.src = "https://turing.captcha.qcloud.com/TCaptcha.js";
			document.body.appendChild(script);
			// #endif
		},
		onShow() {
			this.obj = uni.getStorageSync('capture_succss')
			console.log(uni.getStorageSync('capture_succss'));
			//拿到数据后进行处理
		},
		methods:{
			callback(res) {
				let that = this
				if (res.ret === 0) {
					//验证通过
				} else {
					//验证失败
				}
			},
			varify() {
				// #ifdef H5
				let appid = '194178755';
				let captcha = new TencentCaptcha(appid, this.callback);
				captcha.show();
				// #endif
				// #ifdef APP | MP-WEIXIN
				uni.navigateTo({
					url:'/pages/index/index'
				})
				// #endif
			}
		}
	}
</script>

<style>
</style>

其他页面:

<!--index.html-->
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <script>
      var coverSupport = 'CSS' in window && typeof CSS.supports === 'function' && (CSS.supports('top: env(a)') ||
        CSS.supports('top: constant(a)'))
      document.write(
        '<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0' +
        (coverSupport ? ', viewport-fit=cover' : '') + '" />')
    </script>
    <title></title>
    <!--preload-links-->
    <!--app-context-->
  </head>
  <body>
    <div id="app"><!--app-html--></div>
    <script type="module" src="/main.js"></script>
  </body>
</html>

 App | 小程序 验证页面:

<template>
	<view>
		<!-- #ifdef APP -->
		<web-view src="/hybrid/html/local.html"  @message="callback"></web-view>
		<!-- #endif -->
		<!-- app-id:验证码CaptchaAppId, 从腾讯云的验证码控制台中获取, 在验证码控制台页面内【图形验证】>【验证列表】进行查看 -->
		<!-- #ifdef MP-WEIXIN -->
		<t-captcha
		     id="captcha"
		     app-id="194178755"
		     @verify="handlerVerify"
		     @ready="handlerReady"
		     @close="handlerClose"
		     @error="handlerError" />
		<button @click="login">登录</button>
		<!-- #endif -->
	</view>
</template>
<script>
	export default {
		data() {
			return {
				
			}
		},
		methods: {
			callback: function(res) { //接收网页传给uniapp组件的参数
				let r = res.detail.data[0].res;
				if (r.ret === 0) {
					// #ifdef APP
					uni.setStorageSync('capture_succss',r)
					// #endif
					uni.navigateBack()//接受到参数就可以跳转到想去的界面或者关闭此界面等
				} else {
					console.log('验证失败')
				}
			},
			login: function () {
			    this.selectComponent('#captcha').show()
			    // 进行业务逻辑,若出现错误需重置验证码,执行以下方法
			    // if (error) {
			    // this.selectComponent('#captcha').refresh()
			    // }
			},
			// 验证码验证结果回调
			handlerVerify: function (ev) {
			    // 如果使用了 mpvue,ev.detail 需要换成 ev.mp.detail
			    if(ev.detail.ret === 0) {
			        // 验证成功
			        console.log('ticket:', ev.detail.ticket)
			    } else {
			        // 验证失败
			        // 请不要在验证失败中调用refresh,验证码内部会进行相应处理
			    }
			},    
			// 验证码准备就绪
			handlerReady: function () {
			    console.log('验证码准备就绪')
			},    
			// 验证码弹框准备关闭
			handlerClose: function (ev) {
			    // 如果使用了 mpvue,ev.detail 需要换成 ev.mp.detail,ret为0是验证完成后自动关闭验证码弹窗,ret为2是用户主动点击了关闭按钮关闭验证码弹窗
			    if(ev && ev.detail.ret && ev.detail.ret === 2){
			        console.log('点击了关闭按钮,验证码弹框准备关闭');
			    } else {
			        console.log('验证完成,验证码弹框准备关闭');
			    }
			},
			// 验证码出错
			handlerError: function (ev) {
			    console.log(ev.detail.errMsg)
			}
		},

	}
</script>

App验证需要的H5源码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<meta name="viewport"
			content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
		<title>验证码</title>
		<style type="text/css">
			.app {
				width: 100%;
				height: 50px;
				padding: 20px 10px;
			}
		</style>
	</head>
	<body bgcolor="#121110">
		<div class="app">
			<button id="tencentBtn" class="btn" type="button" data-action="navigateBack">返回</button>
		</div>
		<!-- uni 的 SDK -->
		<!-- 需要把 uni.webview.1.5.4.js 下载到自己的服务器 -->
		<script type="text/javascript" src="https://unpkg.com/@dcloudio/uni-webview-js@0.0.3/index.js"></script>
		<script type="text/javascript" src="https://turing.captcha.qcloud.com/TCaptcha.js"></script>
		
		<script>
	
			document.addEventListener('UniAppJSBridgeReady', function() {	//确认是否加载好了TencentCaptcha
				let appid = '194178755'; // 腾讯云控制台中对应这个项目的 appid
				let callback = function(res) {
					//操作验证码后吧回调信息传递给web-view
					if(res.ret == 0){
						uni.postMessage({
							data: {
								res: res
							}
						});
						document.getElementById('tencentBtn').click()
					}
				}
				let captcha = new TencentCaptcha(appid, callback);
				// 滑块显示
				captcha.show();
				document.querySelector('.app').addEventListener('click', function(evt) {
					var target = evt.target;
					if (target.tagName === 'BUTTON') {
						var action = target.getAttribute('data-action');
						switch (action) { 
							case 'navigateBack':
								uni.navigateBack({
									delta: 1
								});
								break;
							default:
								break;
						}
					}
				});
			});
		</script>
	</body>
</html>

效果展示:

H5:

App:

小程序:


http://www.kler.cn/a/300591.html

相关文章:

  • Armv8/Armv9架构从入门到精通-介绍
  • OpenVela——专为AIoT领域打造的开源操作系统
  • Spark常见面试题-部分待更新
  • 粒子群优化 (PSO, Particle Swarm Optimization) 算法详解及案例分析
  • 【开源免费】基于SpringBoot+Vue.JS欢迪迈手机商城(JAVA毕业设计)
  • 微信原生小程序自定义封装组件(以导航navbar为例)
  • 毕业论文word页眉页脚和页码的问题
  • 【笔记】自动驾驶预测与决策规划_Part1_自动驾驶决策规划简介
  • WinCC Professional 变量的线性转换
  • Java 每日一刊(第4期):Java 23 即将发布
  • CCF编程能力等级认证GESP—C++4级—20240907
  • ES-Search API
  • TCP 拥塞控制:一场网络数据的交通故事
  • Docker 镜像的发布过程
  • 633. 平方数之和-LeetCode(C++)
  • 网络学习-eNSP配置VRRP
  • 【大模型推理】大模型前向推理过程详解
  • PMP–一、二、三模–分类–14.敏捷–技巧–看板面板与燃尽图燃起图
  • VS Code与SVN关联
  • Neo4j图数据库
  • Node.js快速入门
  • 僵尸网络开发了新的攻击技术和基础设施
  • 机器人入门系列:《通过蓝牙模块通讯控制机器人电机转动》
  • Rust在Web开发中的优势是什么?
  • 【lua实战】数组和数组长度
  • Android生成Java AIDL