在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 5972|回复: 23

[原创] 随机数在密码学中的作用(一)随机数分类介绍

[复制链接]
发表于 2020-6-23 13:49:16 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

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

x
一提到密码学,多数人先想到加密算法还有密钥这两个概念。因为算法不同,决定了安全强度不同,而密钥更是安全的核心关键。但除此之外,还有一个因素对密码学至关重要——随机数。本系列文章对随机数的分类和应用做介绍和探讨,本文先对随机数分类进行介绍。
随机数分为伪随机数和真随机数。伪随机数又分为弱伪随机数和强伪随机数。
弱伪随机数
特点是通过纯软件算法,按照一定的规律生成一个随机值。但从名称即可看出,该类随机数的特点是只具备一定的随机性,并不能做到不可预测性,即并不是一个真正的随机数。例如通过MCU的时间作为种子去生成一个随机数,因为时间是不停变化的变量,所以生成的随机数也不停变化。但时间的变化终究有规律可循。
强伪随机数
顾名思义,该类随机数具有更强的随机数特性,能够满足随机性和不可推测特性。例如通过获取敲击键盘的数据作为随机数种子进而生成一组强伪随机数,因为击打键盘存在不确定性,所以生成的随机数也更接近与真正的随机数。
真随机数
同时具备随机性、不可推测和不可重复这3个基本特点。任何人无法通过软件算法或其他方法得知下一个随机数(或者随机数下一位)是什么。真随机数的生成是基于物理现象完成的,例如掷骰子、抛硬币等等。对于嵌入式行业来讲,真随机数是需要借助硬件随机数发生器来产生的。
随机数发生器
可分为真随机数发生器、伪随机数发生器。向下又可细分为硬件真随机数发生器、硬件伪随机数发生器等。这其中只有硬件真随机数发生器对于嵌入式系统应用才是真正安全有效的。
加密芯片属于电子元器件,其运行过程中会产生高斯白噪声,以其作为信息熵资源,产生真随机数。LKT加密芯片符合国际 FIPS-140-2 随机数测试标准。具有高效、资源占用少,生成随机数可靠等优点。可供用户放心使用。
随机数在密码学中的用途主要有:生成nonce、生成salt、生成初始化向量、生成密钥(对称密钥或非对称密钥),详细用法将在下期展开介绍。

发表于 2020-6-24 14:51:03 | 显示全部楼层
随机数除了8位还支持多位吗?
 楼主| 发表于 2020-6-24 16:40:55 | 显示全部楼层


苍茫的天涯是 发表于 2020-6-24 14:51
随机数除了8位还支持多位吗?


你要几位有几位,无限生成啊
发表于 2020-6-24 17:22:34 | 显示全部楼层
随机数还有分类,mark一下,很有用
发表于 2020-6-24 17:26:32 | 显示全部楼层
讲的详细,希望能具体讲一下具体用法
发表于 2020-6-24 18:08:38 来自手机 | 显示全部楼层
LKT这家的加密芯片好像在网上看到过,口碑还是不错的
头像被屏蔽
发表于 2020-6-24 23:48:00 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
发表于 2020-6-25 09:03:21 | 显示全部楼层
什么场景需要真随机数啊?为什么伪随机数不行呢?
头像被屏蔽
发表于 2020-6-25 15:17:41 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
发表于 2020-6-25 17:26:30 | 显示全部楼层
满满的干货,感谢楼主分享!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /2 下一条

小黑屋| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-4-25 15:07 , Processed in 0.027910 second(s), 6 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表