脚本专栏 
首页 > 脚本专栏 > 浏览文章

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

(编辑:jimmy 日期: 2024/11/27 浏览:3 次 )

脚本作用:产生随机密码。每密码字符个数,密码数量,存盘位置等可以自定义。
脚本用法:
脚本采用了硬编码,所以你需要打开脚本,修改如下变量:
$生成密码总个数 = 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 10
if ($最大的10个文件.Length -lt 10)
{
	Write-Error "这个脚本根据大文件作为随机数种子,加随机数产生密码。找不到大文件将无法产生密码。"
	Write-Error "在 $大文件所在盘符 找不到 $大文件类型 文件,或文件总数不够10个"
	exit
}


$密码种子文件 = $最大的10个文件 | Get-Random
Write-Host "这个脚本根据大文件作为随机数种子,加随机数产生密码。找不到大文件将无法产生密码。"
Write-Host $密码种子文件.FullName,$密码种子文件.length

mkdir  $存盘目录
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

$小写加数字 = $小写字母 + $数字
$大小写加数字 = $大写字母 + $小写字母 + $数字
$含特殊符号 = $小写字母 + $数字 + $特殊符号



$小写加数字密码个数 = 0
while ($小写加数字密码个数 -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---完成 $生成密码总个数 个【小写加数字】密码创建---"

$含大写密码个数 = 0
while ($含大写密码个数 -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---完成 $生成密码总个数 个【大写小写加数字】密码创建---"



$含特殊符号密码个数 = 0
while ($含特殊符号密码个数 -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份,放在不同地方,每半年更新。

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

上一篇:PowerShell中使用curl(Invoke-WebRequest)的方法教程
下一篇:详谈Ubuntu PowerShell(小白入门必看教程)
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 网站地图 SiteMap