react native中基于webview的腾讯图形验证码

react native中基于webview的腾讯图形验证码

腾讯验证码

效果实例图

第三方库

复制代码
npm i react-native-webview

react-native-webview

复制代码
import React, { useEffect, useState } from 'react';
import { StyleSheet, Text, View } from 'react-native';
import { WebView } from 'react-native-webview';

const TestWebViewCode = () => {
    const [params, setParams] = useState(null);

    const handleMessage = event => {
        const data = JSON.parse(event.nativeEvent.data);
        // 处理从WebView发送过来的消息
        console.log('[]', data);
        // 在这里可以处理JavaScript回调函数返回的值

        setParams(() => data?.randstr)
    };

    useEffect(() => {
        return () => { };
    }, []);
    return (
        <>
          
                <WebView
                    javaScriptEnabled={true}
                    source={{
                        html: `
                        <!DOCTYPE html>
                        <html lang="en">
                            <head>
                                <meta charset="UTF-8">
                                <meta http-equiv="X-UA-Compatible" content="IE=edge">
                                <meta name="viewport" content="width=device-width, initial-scale=1.0">
                                <title>Web 前端接入示例</title>
                                <!-- 验证码程序依赖(必须)。请勿修改以下程序依赖,如通过其他手段规避加载,会导致验证码无法正常更新,对抗能力无法保证,甚至引起误拦截。 -->
                                <script src="https://turing.captcha.qcloud.com/TCaptcha.js"></script>
                                <style type="text/css">
                                    *{
                                        padding: 0;
                                        margin: 0;
                                        box-sizing: border-box;
                                    }
                                </style>
                            </head>
                            <body></body>
                            <script>
                                // 定义回调函数
                                function callback(res) {
                                    console.log('callback:', res);
                                    window.ReactNativeWebView.postMessage(JSON.stringify(res))
                                }
                                // 定义验证码js加载错误处理函数
                                function loadErrorCallback() {
                                    var appid = '1';
                                    var ticket = 'trerror_1001_' + appid + '_' + Math.floor(new Date().getTime() / 1000);
                                    callback({
                                        ret: 0,
                                        randstr: '@' + Math.random().toString(36).substr(2),
                                        ticket: ticket,
                                        errorCode: 1001,
                                        errorMessage: 'jsload_error'
                                    });
                                }
                                window.onload = function() {
                                    try {
                                        var captcha = new TencentCaptcha('1', callback, {
                                            userLanguage: 'zh-cn',
                                            type:'embed',
                                            showFn: (ret) => {
                                                const {
                                                    duration, // 验证码渲染完成的耗时(ms)
                                                    sid, // 链路sid
                                                } = ret;
                                            }
                                        });
                                        captcha.show();
                                    } catch (error) {
                                        loadErrorCallback();
                                    }
                                }
                            </script>
                        </html>
                        `
                    }}
                    onMessage={handleMessage}
                />
            <Text>返回参数:{params}</Text>
        </>
    );
};
const styles = StyleSheet.create({

});

export default TestWebViewCode;
相关推荐
我爱加班、、3 分钟前
Chrome安装最新vue-devtool插件
javascript·vue.js·chrome·vue-devtool
LuckyLay33 分钟前
React百日学习计划-Grok3
前端·学习·react.js
澄江静如练_37 分钟前
小程序 存存上下滑动的页面
前端·javascript·vue.js
m0_513962531 小时前
vue-ganttastic甘特图label标签横向滚动固定方法
javascript·vue.js·甘特图
码农黛兮_462 小时前
HTML、CSS 和 JavaScript 基础知识点
javascript·css·html
呵呵哒( ̄▽ ̄)"2 小时前
React - 编写选择礼物组件
前端·javascript·react.js
Coding的叶子3 小时前
React Flow 简介:构建交互式流程图的最佳工具
前端·react.js·流程图·fgai·react agent
油丶酸萝卜别吃8 小时前
OpenLayers 精确经过三个点的曲线绘制
javascript
ShallowLin8 小时前
vue3学习——组合式 API:生命周期钩子
前端·javascript·vue.js
Nejosi_念旧8 小时前
Vue API 、element-plus自动导入插件
前端·javascript·vue.js