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;
相关推荐
芳草萋萋鹦鹉洲哦9 小时前
【elemen/js】阻塞UI线程导致的开关卡顿如何优化
开发语言·javascript·ui
1***s63210 小时前
Vue图像处理开发
javascript·vue.js·ecmascript
槁***耿10 小时前
JavaScript在Node.js中的事件发射器
开发语言·javascript·node.js
一叶茶10 小时前
移动端平板打开的三种模式。
前端·javascript
U***498310 小时前
JavaScript在Node.js中的Strapi
开发语言·javascript·node.js
老前端的功夫11 小时前
前端浏览器缓存深度解析:从网络请求到极致性能优化
前端·javascript·网络·缓存·性能优化
颜酱12 小时前
Monorepo 架构以及工具选型、搭建
前端·javascript·node.js
X***489613 小时前
JavaScript在Node.js中的Nx
javascript·node.js·vim
o***Z44813 小时前
JavaScript在Node.js中的内存管理
开发语言·javascript·node.js
我命由我1234513 小时前
微信开发者工具 - 模拟器分离窗口与关闭分离窗口
前端·javascript·学习·微信小程序·前端框架·html·js