首页 > 开发 > PowerShell > 正文

PowerShell脚本 随机密码生成器(ps随机密码生成器)

2020-10-29 20:55:35
字体:
来源:转载
供稿:网友

脚本作用:产生随机密码。每密码字符个数,密码数量,存盘位置等可以自定义。
脚本用法:
脚本采用了硬编码,所以你需要打开脚本,修改如下变量:
$生成密码总个数 = 1000
$每个密码位数 = 12
$存盘目录 = 'e:/脚本ps/log_ps/'
$大文件所在盘符 = 'f:/'
并保存,然后运行脚本,脚本运行的较慢,可以缩小powershell窗口,n分钟后去【$存盘目录】收取生成的密码
文件【小写加数字加特殊符号密码.txt】,【大小写加数字密码.txt】,【小写加数字密码.txt】。
提示:打入盘符+路径+s+<tab>键,脚本名自动补全。

全部代码:

#本脚本会在 $存盘目录 下生成3个文件(小写加数字密码.txt,大小写加数字密码.txt,小写加数字加特殊符号密码.txt)#每个文件中含有 $生成密码总个数 个密码。#这个脚本根据大文件作为随机数种子,加随机数产生密码。找不到大文件将无法产生密码。$生成密码总个数 = 1000$每个密码位数 = 12 $存盘目录 = 'e:/脚本ps/log_ps/'$大文件所在盘符 = 'f:/'[array]$大文件类型 = "*.rmvb","*.mkv","*.mp4","*.avi"$小写加数字密码 = $存盘目录 + '小写加数字密码.txt'$含大写密码 = $存盘目录 + '大小写加数字密码.txt'$含特殊符号密码 = $存盘目录 + '小写加数字加特殊符号密码.txt'#$ErrorActionPreference = "SilentlyContinue"$最大的10个文件 = Get-ChildItem -path $大文件所在盘符 -recurse -force -Include $大文件类型 | Sort-Object length -Descending | select-object -first 10if ($最大的10个文件.Length -lt 10){	Write-Error "这个脚本根据大文件作为随机数种子,加随机数产生密码。找不到大文件将无法产生密码。"	Write-Error "在 $大文件所在盘符 找不到 $大文件类型 文件,或文件总数不够10个"	exit}$密码种子文件 = $最大的10个文件 | Get-RandomWrite-Host "这个脚本根据大文件作为随机数种子,加随机数产生密码。找不到大文件将无法产生密码。"Write-Host $密码种子文件.FullName,$密码种子文件.lengthmkdir  $存盘目录Write-Host "---生成的密码个数:$生成密码总个数 生成位置:$存盘目录 "$文件流 = new-object system.io.filestream($密码种子文件,"open")$null = $文件流.seek(0,0)$reader = new-object System.IO.BinaryReader($文件流)$小写字母 = "a","b","c","d","e","f","g","h","i","j","k","m","n","o","p","q","r","s","t","u","v","w","x","y","z" #小写字母没有字母 l$数字 = "2","3","4","5","6","7","8","9" #没有0,1$大写字母 = "A","B","C","D","E","F","G","H","J","K","L","M","N","P","Q","R","S","T","U","V","W","X","Y","Z" $特殊符号 = "~","!","@","#","$","%","^","&","*","(",")"#大写字母没有字母 I,O$小写加数字 = $小写字母 + $数字$大小写加数字 = $大写字母 + $小写字母 + $数字$含特殊符号 = $小写字母 + $数字 + $特殊符号$小写加数字密码个数 = 0while ($小写加数字密码个数 -lt $生成密码总个数){	$一个密码 = $null	while ($一个密码.length -lt $每个密码位数)	{		$源自文件的随机数 = $reader.Readbyte()		$ps随机数 = 1..50 | Get-Random		$随机数 = $源自文件的随机数 - $ps随机数		if (($随机数 -lt 123) -and ($随机数 -ge 32) )		{			$密码字母 = [char][int]$随机数 			if ($小写加数字 -ccontains $密码字母)			{				$一个密码 = $一个密码 + $密码字母			}		}	}	$结果 = $一个密码		if ($结果 -match "[0-9]+")	{		#洗牌		$结果 = $结果 | Get-Random -Count  $每个密码位数		$结果 >> $小写加数字密码	  Write-Host "."  -NoNewline -ForegroundColor Yellow		$小写加数字密码个数++	}}Write-Host "`n---完成 $生成密码总个数 个【小写加数字】密码创建---"$含大写密码个数 = 0while ($含大写密码个数 -lt $生成密码总个数){	$一个密码 = $null	while ($一个密码.length -lt $每个密码位数)	{		$源自文件的随机数 = $reader.Readbyte()		$ps随机数 = 110..150 | Get-Random		$随机数 = $源自文件的随机数 - $ps随机数		if (($随机数 -lt 123) -and ($随机数 -ge 32) )		{			$密码字母 = [char][int]$随机数 			if ($大小写加数字 -ccontains $密码字母)			{				$一个密码 = $一个密码 + $密码字母			}		}	}	$结果 = $一个密码		if ($结果 -match "[0-9]+")	{		#洗牌		$结果 = $结果 | Get-Random -Count  $每个密码位数		$结果 >> $含大写密码	  Write-Host "."  -NoNewline -ForegroundColor Yellow		$含大写密码个数++	}}Write-Host "`n---完成 $生成密码总个数 个【大写小写加数字】密码创建---"$含特殊符号密码个数 = 0while ($含特殊符号密码个数 -lt $生成密码总个数){	$一个密码 = $null	while ($一个密码.length -lt $每个密码位数)	{		$源自文件的随机数 = $reader.Readbyte()		$ps随机数 = 1..50 | Get-Random		$随机数 = $源自文件的随机数 - $ps随机数		if (($随机数 -lt 123) -and ($随机数 -ge 32) )		{			$密码字母 = [char][int]$随机数 			if ($含特殊符号 -ccontains $密码字母)			{				$一个密码 = $一个密码 + $密码字母			}		}	}	$结果 = $一个密码		if ($结果 -match "[0-9]+")	{		#洗牌		$结果 = $结果 | Get-Random -Count  $每个密码位数		$结果 >> $含特殊符号密码	  Write-Host "."  -NoNewline -ForegroundColor Yellow		$含特殊符号密码个数++	}}Write-Host "`n---完成 $生成密码总个数 个【小写加数字加特殊符号】密码创建---"#Write-Host `n,$文件流.Position$文件流.Dispose()Write-Host "`n---完成3种密码,每种: $生成密码总个数 个密码创建---`n别告诉我你缺密码!`n勤修改密码!" 

打包下载:getpwd_jb51.rar

------【脚本特色】------

不求最快,但求真随机。

伪随机数:
随机密码其实就是随机数的组合而已,.net的随机数生成很快很好,但也是伪随机数。python的随机数功能
也很快很好,但也只是伪随机数而已。生成的都是伪随机数。

真随机数:
没法生成真随机数,只能【取】真随机数。

本脚本之妙:
我写了好几个版本的随机密码生成,开始都是用【调用库,生成伪随机数】法。后来我找到了【取真随机数】的方法,我简直忍不住要赞美我啊,呵呵。

可以自定义随机字符:

比如:本脚本生成器生成的随机数中,默认没有0,1 , i, l,o这些容易混淆的字母。

开放源码,无后门。

脚本缺点:比较慢。

------【脚本原理,流程】------

脚本首先会用dir你的【$大文件所在盘符】。这一步比较慢,无权限会报错的信息我也没关闭,目的是直观。
找出【$大文件类型】定义的10个最大的文件,这些文件默认是 "*.rmvb","*.mkv","*.mp4","*.avi"
没错,就是【从大电影文件中取真随机数】!
随机选其中一个文件,按照一定规则取数,然后组合成固定长度的密码,然后再随机打乱顺序,
然后根据是否有数字,特殊符号,抛弃不符合的随机数。

本脚本另一个妙的地方是:(为了随机故意而为的算法)

即便你锁定(固定)输入源,即大电影文件,
只要文档内,字节内容随机,产生的密码就随机。即2次运行脚本,将产生2个同名文档(当然你要把前面的改名),对比之,发现生成的每个随机数都不同。
如果文档内,字节内容固定,如都是00,255之类,则不会产生密码。

------【最终建议】------

建议5年内更换一次有可能泄密的帐号。如果实在不能换帐号,必须5年内登录(使用)过1次。
超5年不换账号,不登陆的银行卡的钱,都有可能没了。连国家过个10年8年都更改钱的样式。
powershell 传教士 原创文章 2016-02-06 允许转载,但必须保留名字和出处,否则追究法律责任

建议每年更换密码,或者更短的时间更换密码。密码必须复杂,不同帐号的密码绝不相同。

复杂的密码记在电脑上,然后加密。复制3份,放在不同地方,每半年更新。

本人脚本新作【灰主牛 隐私记事本】 正在创作中,敬请期待。。。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表