[英]Human speakable password generator in JavaScript
我正在开发一个脚本,用于生成用于密码的人类可说字符串。 我只关心英语发音的短语。 到目前为止,我已经提出了不同数组的概念:
vowels = ['a','e','i','o','u'];
single_consonants = ['b','c','d','f','g','h','j','k','l','m','n','p','q','r','s','t','v','w','x','y','z'];
double_consonants_leading = ['Bh','Bl','Br','By','Ch','Cl','Cr','Cy','Dr','Dw','Dy','Fl','Fr','Fy','Gh','Gl','Gn','Gr','Gw','Gy','Hy','Jy','Kn','Kr','Kw','Ky','Ly','Mc','Mn','Mr','My','Ny','Ph','Pl','Pn','Pr','Ps','Py','Q','Rh','Ry','Sc','Sh','Sk','Sl','Sm','Sn','Sp','St','Sv','Sw','Sy','Th','Tr','Ts','Tw','Ty','Vr','Vy','Wh','Wr','Wy','Xy','Y','Z'];
double_consonants_trailing = [...'ch'...];
tripple_consonants_leading = [...'Dry','Fly'...];
tripple_consonants_trailing = [...'rch'...];
然后,我将定义一组规则来连接这些数组中的元素以创建字符串,但不一定是您在字典中找到的字。
一个例子是:“ Frug-Spunner-Snow-Drive ”
另一个选择是使用字典中的单词列表,但是,我首先想到的是它是一个有限列表。 只要有人知道你从哪个列表生成字符串就会不可避免地减少破解它的时间。
我的解决方案不仅会创建字典中的单词,还会创建听起来像单词的字符串。
function generateString(length)
{
.
.
.
return randomString;
}
generateString(7);
输出: “Brownen”(随机字符串)
该函数将采用参数长度并返回该长度的字符串,可以通过接受更多参数来改进,例如要使用多少部分以及在这些部分之间使用的分隔符 。
function generateString(parts,lengthOfPart,separator)
{
.
.
.
return randomString;
}
generateString(4,5,"-");
输出: “Crown-Drive-Knife-Gnome”(4个字符串,每个5个字符长,由一个超级分隔)
这是我到目前为止所做的,问题本身就是一项正在进行的工作。 我想确保我走在正确的轨道上。
我的问题是:这有点矫枉过正吗? 优缺点都有什么? 最后,我将如何在JavaScript中开发它?
编辑1(13/11/2013)
我在这里发现了一篇文章: http : //www.baekdal.com/insights/password-security-usability描述了使用常用单词列表,但只要在任何给定时间使用三个+单词就可以了因为打破它所花费的时间很长,所以你想要保护的东西是没有多大价值的。
编辑2(10:10 14/11/2013)
我在Javascript中找到另一篇引用马尔可夫链发生器http://www.soliantconsulting.com/blog/2013/02/draft-title-generator-using-markov-chains的文章,但同样文本是从源文本生成的。 如果没有它并通过定义规则,这是否可能。
我认为一个好方法可能是使用由大量英文文本生成的马尔可夫链。 马尔可夫链基本上是一个概率构造,它依赖于它产生的来源,所以你可能会得到许多类似英语的单词。 在马尔可夫链中,您有一个状态,您可以根据概率转换到许多其他状态。 由于您的马尔可夫链将基于英文文本正文中的英文字母,因此从一个字母到另一个字母的转换比转换到另一个字母更有可能。 例如,它更可能从c
转换为a
或o
,而不是从c
为z
或x
。 我有一个简单的Perl脚本 ,它根据单词或字母生成马尔可夫链,我能够得到以下似乎非常明显的“单词”:
Engulary
Beavy
Lan
Irstatinval
Bassions
Assish
Forld
Anturopean
Cought
Froot
Thation
请记住,虽然熵受到源材料的限制,但最好有一个大的身体,你正在生成单词。 从Diodeus提到的xkcd密码生成器中获取指针 ,您可以将这些单词中的两个或多个组合成可发音但无意义的短语,也可以是密码。
没有单词列表(只有字母定义)的简单例子,对于记忆力非常好的人来说 ......为了获得人类可说的单词,应该添加更多的规则,就像4个元音一样。 结果
Diecrue - Okeiae - Auasvei
Aovaua - Biaeeo - Suwien
Aiasmea - Aueglou - Koiroa
Doiiui - Domeab - Slokaoa
Oeiuju - Yootraa - Koaeua
Qagwisva - Hiexau - Yovaca
Fleeaee - Peaoui - Xafriaa
Vaaute - Iqovai - Naaaesn
Yauehe - Ueeguu - Mrouiepr
Smikreua - Friusnut - Aoqiji
主要代码: http : //jsfiddle.net/mMZ3Y/
function get_password_word(n){
var data1 = ['a','e','i','o','u'];
var data2 = ['b','c','d','f','g','h','j','k','l','m','n','p','q','r','s','t','v','w','x','y','z'];
var data3 = ['bl','br','cl','cr','dr','dw','fl','fr','gl','gr','gw','kn','kr','kw','mr','ph','pl','pn','pr','ps','sc','sh','sk','sl','sm','sn','sp','st','sv','sw','tr','ts','wh'];
var str = '';
var last = '';
for(var i = 0; i < n; i++){
var type = getRandomInt(1, 10);
//avoiding some cases
if(last == 3)
type = 1;
if(last == 2)
type = 1;
if(last == 1 && getRandomInt(1, 2) == 1)
type = 2;
//generate
if(type < 4){ //40%
str += data1[getRandomInt(0, data1.length-1)];
last = 1;
}
else if(type < 9){ //40%
str += data2[getRandomInt(0, data2.length-1)];
last = 2;
}
else{ //20%
str += data3[getRandomInt(0, data3.length-1)];
last = 3;
}
}
str = str.charAt(0).toUpperCase() + str.slice(1);
return str;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.