网站首页 > 技术文章 正文
短信验证码的几种生成方式
1.前言
在用户登录模块中,利用手机号+短信验证码的方式进行登录,是目前比较常见的一种登录方式,那么短信验证码怎么生成呢?这里所说的短信验证码,通常是指6位的随机数字,那么下面我就说一下我们开发中用到过的几种验证码生成方式,仅供参考。
2.生成方式
1.第一种方式
/**
* 生成?位的数字类型的短信验证码
* @param count
* @return
*/
public static String generatedcode(int count) {
List<Integer> set = getRandomNumber(count);
// 使用迭代器
Iterator<Integer> iterator = set.iterator();
// 临时记录数据
String temp = "";
while (iterator.hasNext()) {
temp += iterator.next();
}
return temp;
}
/**
* 返回?位的随机数字
* @param count
* @return
*/
public static List<Integer> getRandomNumber(int count) {
// 使用SET以此保证写入的数据不重复
List<Integer> set = new ArrayList<Integer>();
// 随机数
Random random = new Random();
while (set.size() < count) {
// nextInt返回一个伪随机数,它是取自此随机数生成器序列的、在 0(包括)
// 和指定值(不包括)之间均匀分布的 int 值。
set.add(random.nextInt(10));
}
return set;
}
public static void main(String[] args) {
System.out.println(generatedcode(6));
}
这种方式生成的短信验证码,数字不会重复,并且还可以控制某些数字是否出现。
2.第二种生成方式
/**
* 生成?位的数字类型的短信验证码
*
* @param count
* @return
*/
public static String generatedcode(int count) {
String code = (Math.random() + "").substring(2, 2 + count);
return code;
}
public static void main(String[] args) {
System.out.println(generatedcode(6));
}
利用Math.random()这个方法,利用字符串截取方式生成,代码简单、明了,但是不能保证短信验证码中的数字不重复,当然这个是否要过滤掉重复数据,好像也不是很重要。
3.第三种方式
/**
* 生成?位的数字类型的短信验证码
*
* @param count
* @return
*/
public static String generatedcode(int count) {
String code = String.valueOf((int)((Math.random()*9+1)* Math.pow(10,count-1)));
return code;
}
public static void main(String[] args) {
System.out.println(generatedcode(4));
}
这种方式的写法也比较简洁,但是不太容易想,涉及的计算比较复杂一些,用到了幂运算。
Math.random说明:
Math.random()表示的范围是 [0,1)的前闭后开区间,0~0.1,0.1~0.2的每个区间都是等概率的
Math.random() * 9表示[0,9)的double类型的随机数
Math.random() * 9 + 1表示[1,10)的double类型的随机数
Math.pow(10,5)表示底数是10的5次方的double类型的数
(Math.random() * 9 + 1) * Math.pow(10,5)表示[100000,1000000)的double类型的随机数
(int)((Math.random() * 9 + 1) * Math.pow(10,5))表示[100000,999999]范围内的int类型的随机数
因此可以用来生成6位纯数字的手机短信验证码
3.三种方式的比较
1.代码编写上比较
显示第二种和第三种方式代码简单明了,代码量也比较少,但是第三种不容易想到,涉及到的计算有些复杂,可能初中知识是不行的,至少要高中。
2.数字去重
显示第一种方式生成的短信验证码中没有重复数字,第二种和第三种方式都可能会出现重复数字。
3.性能
我这里写了个main方法简单测试一下:
public static void main(String[] args) {
long start = System.currentTimeMillis();
for (int i = 0; i < 1000000; i++) {
generatedcode(6);
}
long end = System.currentTimeMillis();
System.out.println("耗时:" + (end - start));
}
结果如下:
方式 | 结果(毫秒) |
第一种方式 | 540毫秒左右 |
第二种方式 | 680毫秒左右 |
第三种方式 | 160毫秒左右 |
通过上面的比较,如果没有要求数字不允许重复,建议使用第三种方式,效率比较高。
原文链接:
https://blog.csdn.net/lvxinchun/article/details/112155117?utm_medium=distribute.pc_relevant.none-task-blog-2~default~baidujs_baidulandingword~default-0-112155117-blog-123754690.pc_relevant_paycolumn_v3&spm=1001.2101.3001.4242.1&utm_relevant_index=3
猜你喜欢
- 2024-12-18 Java开发中MongoDB数据库相关操作
- 2024-12-18 HashMap有几种遍历方法?推荐使用哪种?
- 2024-12-18 在RedisTemplate中使用scan代替keys指令
- 2024-12-18 MQ的发布订阅模式(fanout) mq几种消息模式
- 2024-12-18 Mybatis参数-ParameterMapping处理参数
- 2024-12-18 既然有MySQL了,为什么还要有MongoDB?
- 2024-12-18 Java遍历一个 List 有哪些方式?每种的实现原理以及哪种最高效?
- 2024-12-18 为什么很多人不愿意用hibernate了?
- 2024-12-18 Qt中 QMap 类、QHash 类、QVector 类详解
- 2024-12-18 半小时搞懂 IO 模型 io模型详解
- 最近发表
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (76)
- js判断是否是json字符串 (75)
- c语言min函数头文件 (77)
- asynccallback (87)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 无效的列索引 (74)