唐诗密码本——用唐诗生成随机密码

2015-09-18 17:22:22 +08:00
 mfhh
# 唐诗密码本

![ss]( https://github.com/fangj/mima/blob/master/screenshot/screenshot01.png?raw=true )

### 怎么使用?

如果你不知道怎么编一个复杂的密码,那么随机生成一个. 比如"SDSGB9H". 可是这是个什么鬼怎么记?! 来,背一句唐诗就好了. "上帝深宫闭九阍". 拼音首字就是. 而且有数字的哦. 密码级别很高的. 如果有天忘了,凭模糊的印象去翻李商隐的诗集. 或许能找出来的.

###灵感词怎么用?

如果你输入了灵感词,密码句子里会尽量包含这个词.但是不保证有. 比如你希望给自己的工商银行账号起密码,但是又怕不好记.可以以"工商"为灵感词.生成"GSCWQ , NMDSB" (工商彻屋去,牛马登山避)(大水-白居易). 如果希望有数字 3.可以用"三"做灵感词,得到如"MJZWWXY , XZ3ZBYR"(盟经早晚闻仙语,学种三芝伴羽人)这样的密码.

### 开源项目

这是一个开源项目, <https://github.com/fangj/mima>, 用 express,angular 搭建. 欢迎小伙伴到 github 上点小星星.

### 开发者

npm install
npm start
访问 http://localhost:3000

### 感谢

本项目使用了这些小伙伴的贡献:

* <https://github.com/hxgdzyuyi/tang_poetry>
* <https://github.com/hotoo/pinyin>

### 关于我

方健,湖建血统的南京土著. 养着一只肥白的中华田园猫. 有很多有趣的想法,就是没空做 T T.

加微信的同学请给我发红包. 谢谢!

![微信]( https://github.com/fangj/mima/blob/master/public/images/wechat_fangjian.jpg?raw=true )
8353 次点击
所在节点    分享创造
22 条回复
lhbc
2015-09-18 17:30:54 +08:00
已加入密码库全家桶,感谢楼主。
mfhh
2015-09-18 17:40:15 +08:00
忘了发链接了 http://mima.treenote.net
怎么修改自己的主题?
oott123
2015-09-18 17:43:13 +08:00
楼主你有没有想过,这样其实就只是一个大字典,你这个项目,危害性不要太大……
hging
2015-09-18 17:44:25 +08:00
1L.哈哈哈哈哈
mfhh
2015-09-18 17:48:42 +08:00
@oott123 这个大字典就是全唐诗。。。 暴力破解如果用这么大的字典。暴力破解意义就不大了。如果真有人这么干。我就改文学作品库。。
mfhh
2015-09-18 17:50:35 +08:00
@oott123 使用者还可以切换大小写组合,特殊标点断句什么的往里面掺沙子。
cloudy9101
2015-09-18 18:29:25 +08:00
有创意, 但是我不想背诗... 2333
lonelygo
2015-09-18 19:07:38 +08:00
是不是考虑再加一个个人定义的转码逻辑?
这样就是进了 1L 密码库全家桶,依然无法逆向
即使是个大字典,少了转码,别人依然搞不定
ryd994
2015-09-18 21:39:10 +08:00
@lonelygo 所谓字典,就是以数量盖复杂度。只要知道唐诗出现过的组合概率更高就行了。
realpg
2015-09-18 21:51:17 +08:00
@mfhh
全唐诗首字母缩写固定组合这么点数据量,作为字典根本不叫大好不好……
没有个 GB 的容量哪好意思说叫大字典
Jocktaa
2015-09-18 22:21:26 +08:00
靠,以后不能拿唐诗做密码了。。。。
echo1937
2015-09-18 22:23:40 +08:00
随机密码的优点在于长度和随机性,唐诗首字母看似随机又好记,其实就是就是个字典,而且以全唐诗那点数据量,加上宋词也不会太大(况且大部分人懂的唐诗宋词也就那么一点)。

如果改变转码定义,那么随机性会增加,好记程度又会降低,似乎无法兼顾。
vpncup
2015-09-18 22:31:25 +08:00
可以在规则中加入打油诗
Marfal
2015-09-18 22:40:08 +08:00
@mfhh 没强度的,自己用还可以,用的人多了分分钟破解。
mfhh
2015-09-19 09:03:40 +08:00
人类密码=好记+随机性
密码本解决的是=好记+伪随机

我同意 @lonelygo 说的要加个人转码逻辑。设计上就是这么考虑的。但是这个转码逻辑不加在程序里,留给用户自己。不是作者偷懒,而是这样才安全。

无论程序如何加规则,出来的都是大字典。
最终使用的时候建议是用户根据自己的个性掺沙子(用户个性规则)。
最终密码 = 程序建议密码(好记+伪随机)+ 用户个性规则(用户个人方便记忆+更强的随机)

比如密码本生成全的是大写的『 MJZWWXY , XZ3ZBYR 』 这是个种子密码。
用户在这个基础上有无数中排列组合
『 MJZWWXY , XZ3ZBYR 』 ->

简单无标点: MJZWWXYXZ3ZBYR
替换标点: MJZWWXY#XZ3ZBYR
每句取首 2 个大写,其余小写: MJzwxy,XZ3zbyr
每句只取前四个字: MJZWXZ3Z
加上用户偏好的固定数字: MJZWXZ3Z1314

还有类似『飞流直下三千尺』,程序给的建议是 FLZX3QC. 用户完全可以用 flzx3000 ,或者 flzx3kc

这样的排列组合对原字典扩大很多种可能,同时,因为『沙子』不在程序里,所以更加安全。

沙子用户自己掺有 2 个好处:
1. 自己想出来的沙子好记
2. 沙子在用户脑子里:安全

如果既然要用户费脑子想沙子还要密码本有什么用?

沙子本身可以安全性很差,可能只有 1~2 位,可能用户长期都用一样的沙子。
real_password= pesdo_password (机器生成的)+simple_password (用户生成的)

沙子本身可能只是一个变幻规则,要作用到一个字符串上才能成为实体密码
real_password=userTransfer (pesdo_password )

沙子对用户本人是好记的。有较弱的安全度。

伪密码对知道明文的所有人是好记的。有一般的安全度。

伪密码+沙子=只对用户本人是好记的。有较强的安全度。

自己搜了下『唐诗密码本』,发现下文,不是我写的。想法很相似。
http://www.360doc.com/content/10/0520/16/114824_28577582.shtml
mfhh
2015-09-19 09:35:24 +08:00
演示下如何掺沙子。 为了方便理解。不用英文了。中文请脑补为拼音。
伪随机母密码:『两个黄鹂鸣翠柳』
=>
黄鹂鸣翠柳
2 个黄鹂鸣翠柳
两个黄鹂鸣:翠柳
两个 /黄鹂 /鸣翠柳
2 个 /黄鹂 /鸣:翠柳
2 个 /y 鹂:鸣翠柳 (注: y 是 yellow 的意思)
2 个 /y 鹂,鸣:gt (注: gt 是 green tree 的意思)
2bmgt (注: two birds 鸣 green tree )
两个黄鹂在 V2EX 鸣翠柳

采用唐诗的意义在于,由于母密码是有语言含义的,用户可以做很多变幻,又不丧失可记忆性。
为了避免母密码过于集中,唐诗密码本采用的是全唐诗,字数是唐诗 300 首的 140 倍。
加上类似上面的 特殊符号断句,数字化,英文化,减字, 增字 等多种变幻手法排列组合,一个母密码可以变幻几百倍。

从另一个角度说,一般用户用的密码强度就比密码本生成的高?很多都还不如。为什么不用复杂的随机密码呢?因为没法记。所以不实用。 密码本的目的是让有一定强度的密码能够真正用起来。还是那句话,不要求跑过狮子,跑过慢的就行。不要求密码无懈可击,比原来的强度好就行。 密码本的目的,是寻找一个『好记』和『强度』的平衡。
Delbert
2015-09-19 11:02:33 +08:00
蓝鲸 同在蓝鲸
Ncer
2015-09-20 11:47:18 +08:00
挺好,支持
monk
2015-09-20 20:35:05 +08:00
出来五言诗,不符最少 6 字符的要求呢
mfhh
2015-09-22 16:42:24 +08:00
@monk 2 句一起用嘛

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/221798

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX