文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

java随机验证码生成实现实例代码

2023-05-31 15:18

关注

java随机验证码生成实现实例代码

摘要: 在项目中有很多情况下都需要使用到随机验证码,这里提供一个java的随机验证码生成方案,可以指定难度,生成的验证码可以很方便的和其他组件搭配

之前要使用一个生成随机验证码的功能,在网上找了一下,有很多的人提出了不同的解决方案,但是很多人都使用了com.sun.image.这个包或者子包里面的类,而这个包结构下面的类都是不推荐使用的,我们应该依赖于java.或者javax.这些包结构下面的类,否则将来的可移植性就很不好(比如换成IBM的JDK就不行了),但是还是有人没有用这些类也做成了的,所以我就在这些代码的基础上,修改了之后做成了下面的工具类,大家可以随意使用,同时也欢迎提出改进意见。

        在jdk1.7.45运行通过。

        首先是验证码生成,可以选择难度:

package cn.songxinqiang.tool.util;import java.util.Arrays;public class RandomSecurityCode {  public enum SecurityCodeLevel { Simple, Medium, Hard }; // 字符集合(除去易混淆的数字0、数字1、字母l、字母o、字母O) private final char[] CHAR_CODE = { '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'm', 'n', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z' };  public char[] getSecurityCode() { return getSecurityCode(4, SecurityCodeLevel.Medium, false); }  public char[] getSecurityCode(int length, SecurityCodeLevel level, boolean isCanRepeat) { // 随机抽取len个字符 int len = length; char[] code; // 根据不同的难度截取字符数组 switch (level) { case Simple: { code = Arrays.copyOfRange(CHAR_CODE, 0, 9); break; } case Medium: { code = Arrays.copyOfRange(CHAR_CODE, 0, 33); break; } case Hard: { code = Arrays.copyOfRange(CHAR_CODE, 0, CHAR_CODE.length); break; } default: { code = Arrays.copyOfRange(CHAR_CODE, 0, CHAR_CODE.length); } } // 字符集合长度 int n = code.length; // 抛出运行时异常 if (len > n && isCanRepeat == false) { throw new RuntimeException(String.format(  "调用SecurityCode.getSecurityCode(%1$s,%2$s,%3$s)出现异常,"  + "当isCanRepeat为%3$s时,传入参数%1$s不能大于%4$s", len,  level, isCanRepeat, n)); } // 存放抽取出来的字符 char[] result = new char[len]; // 判断能否出现重复的字符 if (isCanRepeat) { for (int i = 0; i < result.length; i++) { // 索引 0 and n-1 int r = (int) (Math.random() * n); // 将result中的第i个元素设置为codes[r]存放的数值 result[i] = code[r]; } } else { for (int i = 0; i < result.length; i++) { // 索引 0 and n-1 int r = (int) (Math.random() * n); // 将result中的第i个元素设置为codes[r]存放的数值 result[i] = code[r]; // 必须确保不会再次抽取到那个字符,因为所有抽取的字符必须不相同。 // 因此,这里用数组中的最后一个字符改写codes[r],并将n减1 code[r] = code[n - 1]; n--; } } return result; }}

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 资料下载
  • 历年真题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯