全栈的自我修养 ———— react实现滑动验证

展示

在这里插入图片描述
在这里插入图片描述

依赖

npm install rc-slider-captcha
npm install create-puzzle

api地址

实现

不借助create-puzzle

需要准备两张图片一个是核验图形,一个是原图------> 这个方法小编试了后感觉比较麻烦,这边就不继续写了
在这里插入图片描述

借助create-puzzle

这个工具会接受一个照片,然后自动分割出适当的验证尺寸
在其中bgSize必须要注意!!属性必须和图片一样!!!!!!!!
在这里插入图片描述

import SliderCaptcha from 'rc-slider-captcha';
import React, { useRef } from 'react';
import { sleep } from 'ut2';
import createPuzzle from 'create-puzzle';
import { RubyOutlined, MehOutlined, SmileOutlined, RedoOutlined, LoadingOutlined } from '@ant-design/icons'
// 这里是你要自己准备的图片
import pic from '../static/soildCaptcha.jpeg'
const SoildCaptcha = (params) => {
    const offsetXRef = useRef(0); // x 轴偏移值
    // 查看是否在安全距离
    const verifyCaptcha = async (data) => {
        await sleep();
        if (data.x >= offsetXRef.current - 5 && data.x < offsetXRef.current + 5) {
            setTimeout(() => {
                params.onSuccess()
            }, 1000)
            return Promise.resolve();
        }
        return Promise.reject();
    };
    return (
        <div className='container'>
            <SliderCaptcha
                request={() =>
                    createPuzzle(pic, {
                        format: 'blob'
                    }).then((res) => {
                        offsetXRef.current = res.x
                        return {
                        // 背景图片
                            bgUrl: res.bgUrl,
                            // 核验区域
                            puzzleUrl: res.puzzleUrl
                        };
                    })
                }
                onVerify={(data) => {
                    return verifyCaptcha(data);
                }}
                // !!!!这里是重点!!!!!
                // bgSize必须和原图片的尺寸一样!!!!!!!!!!!!!!!!!!
                bgSize={{ width: 462, height: 266 }}
                tipIcon={{
                    default: <RubyOutlined />,
                    loading: <LoadingOutlined />,
                    success: <SmileOutlined />,
                    error: <MehOutlined />,
                    refresh: <RedoOutlined />
                }}
                tipText={{
                    default: '向右👉拖动完成拼图',
                    loading: '👩🏻‍💻🧑‍💻努力中...',
                    moving: '向右拖动至拼图位置',
                    verifying: '验证中...',
                    error: '验证失败'
                }}
            // loadingBoxProps={{
            //   icon: <Heart />,
            //   text: "I'm loading"
            // }}
            />
        </div>
    );
}

export default SoildCaptcha;

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-10 12:18:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-10 12:18:05       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-10 12:18:05       82 阅读
  4. Python语言-面向对象

    2024-04-10 12:18:05       91 阅读

热门阅读

  1. 【Livox激光MID-360】调试记录

    2024-04-10 12:18:05       40 阅读
  2. 深入剖析OR与UNION的区别及应用场景

    2024-04-10 12:18:05       38 阅读
  3. python实现pdf的页面替换

    2024-04-10 12:18:05       31 阅读
  4. 【SQL】mysql数据库常见函数功能、适用场景

    2024-04-10 12:18:05       35 阅读
  5. swagger记录

    2024-04-10 12:18:05       39 阅读
  6. NPM常用命令及详解

    2024-04-10 12:18:05       29 阅读
  7. 用ChatGPT4.0生成美观的PDF

    2024-04-10 12:18:05       32 阅读