当前位置:首页 > 科技  > 软件

一款小而美的开源滑动验证码组件

来源: 责编: 时间:2023-12-08 09:14:17 161观看
导读hi, 大家好, 我是徐小夕, 今天给大家分享一款非常有意思的开源组件, 可以实现我们平时开发中的滑动验证码需求, 当然也是技术圈小伙伴奋战了无数个黑夜和白天的结果, 值得好好推荐一下.图片react-rotate-captcha 是一

hi, 大家好, 我是徐小夕, 今天给大家分享一款非常有意思的开源组件, 可以实现我们平时开发中的滑动验证码需求, 当然也是技术圈小伙伴奋战了无数个黑夜和白天的结果, 值得好好推荐一下.8Gd28资讯网——每日最新资讯28at.com

图片图片8Gd28资讯网——每日最新资讯28at.com

react-rotate-captcha 是一款开箱即用的滑动验证码 React 组件,基于 isszz/rotate-captcha 做的二次开发;结合了腾讯防水墙,增加安全策略.8Gd28资讯网——每日最新资讯28at.com

具体策略由两部分组成:8Gd28资讯网——每日最新资讯28at.com

  • policie默认策略
  • rules策略组规则

策略规则:8Gd28资讯网——每日最新资讯28at.com

  • limit: 上限次数,达到峰值后重新验证,0不限制
  • time: 使用期限,过期后重新验证,0不限制
  • routers: 匹配要授权的路由组,null全匹配

这里的路由是指验证通过后,要执行操作的路由,而不是验证操作时的路由8Gd28资讯网——每日最新资讯28at.com

图片图片8Gd28资讯网——每日最新资讯28at.com

原理:8Gd28资讯网——每日最新资讯28at.com

  • 验证通过后将颁发:sid、ticket
  • 执行操作时验证决定是否通过,通过就去和执行的route进行匹配
  • 从而避免跨权,跨范围执行

优点:8Gd28资讯网——每日最新资讯28at.com

  • 针对不同应用场景提供验证
  • 例如登录验证有效期30分钟,后台操作按次数进行身份验证

后端提供 Laravel 扩展:levi/laravel-rotate-captcha ,可直接使用或根据 Api 接口定制.8Gd28资讯网——每日最新资讯28at.com

效果如下:8Gd28资讯网——每日最新资讯28at.com

图片图片8Gd28资讯网——每日最新资讯28at.com

设计思路

图片图片8Gd28资讯网——每日最新资讯28at.com

具体的使用安装方式如下:8Gd28资讯网——每日最新资讯28at.com

// yarn安装yarn add react-rotate-captcha// pnpm安装pnpm add react-rotate-captcha

使用方式如下:8Gd28资讯网——每日最新资讯28at.com

// 1. 通过status唤起import { useState } from 'react';import RotateCaptcha from "react-rotate-captcha";function App() {    const [open, setOpen] = useState(true);    return <RotateCaptcha open={open} onClose={() => setOpen(false)} />}// 2. 通过Instance唤起import RotateCaptcha from "react-rotate-captcha";function Page() {    const captcha = RotateCaptcha.useCaptchaInstance();    return (        <button onClick={() => captcha.open()}>click it</button>    );}function App() {    return (        <RotateCaptcha>            <Page />        </RotateCaptcha>    );}

当然我们也可以使用 ref 来实现同样的效果:8Gd28资讯网——每日最新资讯28at.com

import { useRef } from 'react';import RotateCaptcha, { CaptchaInstance } from "react-rotate-captcha";function App() {    const ref = useRef<CaptchaInstance>(null);    return (        <RotateCaptcha ref={ref}>            <button onClick={() => ref.current!.open()}>click it</button>        </RotateCaptcha>    );}

基本属性介绍:8Gd28资讯网——每日最新资讯28at.com

图片图片8Gd28资讯网——每日最新资讯28at.com

同时该组件接受5个方法,只有 onClose 和 result 是同步函数,其余全部为异步函数:8Gd28资讯网——每日最新资讯28at.com

图片图片8Gd28资讯网——每日最新资讯28at.com

更详细的用法大家可以在github上学习参考:8Gd28资讯网——每日最新资讯28at.com

https://github.com/cgfeel/react-rotate-captcha8Gd28资讯网——每日最新资讯28at.com

demo 目前提供了 webpack 和 vite 版本的, 可以在: https://codesandbox.io/p/devbox/react-rotate-captcha-ts-react-vite-t23lcq 体验.8Gd28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-39506-0.html一款小而美的开源滑动验证码组件

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Java 21 的虚拟线程:高性能并发应用的福音

下一篇: 这套分布式IM即时通讯系统如何写到简历上?我给你整理好了!

标签:
  • 热门焦点
Top