翼度科技»论坛 编程开发 JavaScript 查看内容

Vue滑块验证码组件anji-captcha的使用案例详解

1

主题

1

帖子

3

积分

新手上路

Rank: 1

积分
3
说明

最近需要改一下首页界面,将之前的字符验证码改成滑块验证码(这样更好用一些),找了一下发现了anji-captcha这个组件,效果如下


快速开始


前端

首先将仓库克隆下来->https://github.com/anji-plus/captcha.git,然后在自己的工程里copy需要的文件
  1. 1)复制view/vue/src/components/verifition文件夹,到自己工程对应目录下
  2. 复制view/vue/src/assets到自己工程对应目录下
  3. 2)安装请求和加密依赖
  4. npm install axios  crypto-js   -S
复制代码
前端请求使用的axios,需要换成自己工程的axios,这样请求后端路径才会正确,配置位于verifition/api/index.js,同时如果后端有对请求拦截请过滤掉/captcha/get和/captcha/check两个后端接口
示例使用
  1. <template>
  2.   <div>
  3.     <Verify
  4.       @success="success"
  5.       :mode="'pop'"
  6.       :captchaType="'blockPuzzle'"
  7.       :imgSize="{ width: '330px', height: '155px' }"
  8.       ref="verify"
  9.     ></Verify>
  10.     <button @click="useVerify">调用验证组件</button>
  11.   </div>
  12. </template>
  13. <script>
  14. //引入组件
  15. import Verify from "@/components/verifition/Verify";
  16. export default {
  17.   name: "app",
  18.   components: {
  19.     Verify,
  20.   },
  21.   methods: {
  22.     success(params) {
  23.         console.log("成功,下面是二次验证")
  24.       // params 返回的二次验证参数, 和登录参数一起回传给登录接口,方便后台进行二次验证
  25.     },
  26.     useVerify() {
  27.       this.$refs.verify.show();
  28.     },
  29.   },
  30. };
  31. </script>
复制代码
后端

有starter版本的包,还是比较方便的
  1.         <dependency>
  2.             <groupId>org.springframework.boot</groupId>
  3.             <artifactId>spring-boot-starter-data-redis</artifactId>
  4.         </dependency>
  5.         <dependency>
  6.             <groupId>com.anji-plus</groupId>
  7.             <artifactId>spring-boot-starter-captcha</artifactId>
  8.             <version>1.2.8</version>
  9.         </dependency>
复制代码
application.yml
  1. server:
  2.   port: 8080
  3. # 滑动验证,底图路径,不配置将使用默认图片
  4. # 支持全路径
  5. # 支持项目路径,以classpath:开头,取resource目录下路径,例:classpath:images/jigsaw
  6. spring:
  7.   redis:
  8.     database: 3
  9.     host: 151.168.99.100
  10.     password: '123456'
  11.     port: 6379
  12. aj:
  13.   captcha:
  14.     jigsaw: classpath:images/jigsaw
  15.     #滑动验证,底图路径,不配置将使用默认图片
  16.     ##支持全路径
  17.     # 支持项目路径,以classpath:开头,取resource目录下路径,例:classpath:images/pic-click
  18.     pic-click: classpath:images/pic-click
  19.     # 对于分布式部署的应用,我们建议应用自己实现CaptchaCacheService,比如用Redis或者memcache,
  20.     # 参考CaptchaCacheServiceRedisImpl.java
  21.     # 如果应用是单点的,也没有使用redis,那默认使用内存。
  22.     # 内存缓存只适合单节点部署的应用,否则验证码生产与验证在节点之间信息不同步,导致失败。
  23.     # !!! 注意啦,如果应用有使用spring-boot-starter-data-redis,
  24.     # 请打开CaptchaCacheServiceRedisImpl.java注释。
  25.     # redis ----->  SPI: 在resources目录新建META-INF.services文件夹(两层),参考当前服务resources。
  26.     # 缓存local/redis...
  27.     cache-type: redis
  28.     # local缓存的阈值,达到这个值,清除缓存
  29.     cache-number: 1000
  30.     # local定时清除过期缓存(单位秒),设置为0代表不执行
  31.     timing-clear: 180
  32.     # 验证码类型default两种都实例化。
  33.     type: default
  34.     # 汉字统一使用Unicode,保证程序通过@value读取到是中文,可通过这个在线转换;yml格式不需要转换
  35.     # https://tool.chinaz.com/tools/unicode.aspx 中文转Unicode
  36.     # 右下角水印文字(我的水印)
  37.     water-mark: Yunlingfly
  38.     # 右下角水印字体(不配置时,默认使用文泉驿正黑)
  39.     # 由于宋体等涉及到版权,我们jar中内置了开源字体【文泉驿正黑】
  40.     # 方式一:直接配置OS层的现有的字体名称,比如:宋体
  41.     # 方式二:自定义特定字体,请将字体放到工程resources下fonts文件夹,支持ttf\ttc\otf字体
  42.     # aj.captcha.water-font=WenQuanZhengHei.ttf
  43.     # 点选文字验证码的文字字体(文泉驿正黑)
  44.     # aj.captcha.font-type=WenQuanZhengHei.ttf
  45.     # 校验滑动拼图允许误差偏移量(默认5像素)
  46.     slip-offset: 5
  47.     # aes加密坐标开启或者禁用(true|false)
  48.     aes-status: true
  49.     # 滑动干扰项(0/1/2)
  50.     interference-options: 1
  51.     history-data-clear-enable: true
  52.     # 接口请求次数一分钟限制是否开启 true|false
  53.     req-frequency-limit-enable: true
  54.     # 验证失败5次,get接口锁定
  55.     req-get-lock-limit: 5
  56.     # 验证失败后,锁定时间间隔,s
  57.     req-get-lock-seconds: 60
  58.     # get接口一分钟内请求数限制
  59.     req-get-minute-limit: 30
  60.     # check接口一分钟内请求数限制
  61.     req-check-minute-limit: 60
  62.     # verify接口一分钟内请求数限制
  63.     req-verify-minute-limit: 60
复制代码
将service/springboot/src/main/resources下的images和METE-INF文件夹copy到自己的工程里,将CaptchaCacheService文件里的内容改为自己的目录并新建CaptchaCacheServiceRedisImpl文件作为缓存,内容如下
  1. package cn.yunlingfly.springbootanjicaptcha.service;
  2. import com.anji.captcha.service.CaptchaCacheService;
  3. import org.springframework.beans.factory.annotation.Autowired;
  4. import org.springframework.data.redis.core.StringRedisTemplate;
  5. import java.util.concurrent.TimeUnit;
  6. /**
  7. * 对于分布式部署的应用,我们建议应用自己实现CaptchaCacheService,比如用Redis,参考service/spring-boot代码示例。
  8. * 如果应用是单点的,也没有使用redis,那默认使用内存。
  9. * 内存缓存只适合单节点部署的应用,否则验证码生产与验证在节点之间信息不同步,导致失败。
  10. * <p>
  11. * ☆☆☆ SPI: 在resources目录新建META-INF.services文件夹(两层),参考当前服务resources。
  12. * <p>
  13. * 使用redis缓存
  14. *
  15. * @author lide1202@hotmail.com
  16. * @date 2020-05-12
  17. */
  18. public class CaptchaCacheServiceRedisImpl implements CaptchaCacheService {
  19.     @Override
  20.     public String type() {
  21.         return "redis";
  22.     }
  23.     @Autowired
  24.     private StringRedisTemplate stringRedisTemplate;
  25.     @Override
  26.     public void set(String key, String value, long expiresInSeconds) {
  27.         stringRedisTemplate.opsForValue().set(key, value, expiresInSeconds, TimeUnit.SECONDS);
  28.     }
  29.     @Override
  30.     public boolean exists(String key) {
  31.         return stringRedisTemplate.hasKey(key);
  32.     }
  33.     @Override
  34.     public void delete(String key) {
  35.         stringRedisTemplate.delete(key);
  36.     }
  37.     @Override
  38.     public String get(String key) {
  39.         return stringRedisTemplate.opsForValue().get(key);
  40.     }
  41.     @Override
  42.     public Long increment(String key, long val) {
  43.         return stringRedisTemplate.opsForValue().increment(key, val);
  44.     }
  45. }
复制代码
测试

前后端分别启动后,浏览器访问http://localhost:3000/#/captcha即可看到结果

为了方便测试,我将我前后端都上传到Github了,代码戳
前端->https://github.com/Yunlingfly/vue-captcha
后端->https://github.com/Yunlingfly/springboot-anji-captcha
官方文档->AJ-Captcha在线体验
到此这篇关于Vue滑块验证码组件anji-captcha的使用的文章就介绍到这了,更多相关Vue滑块验证码内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

来源:https://www.jb51.net/javascript/284484ifs.htm
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具