Unix操作系统脚本的讲解

系统 其他OS
Unix操作系统使用root权限,调用passwd命令,定时修改用户的密码。 但是由于passwd命令比较特殊,要求必须人机交互状态下输入新密码,因此使用一般的方式无法实现完全自动化。

Unix操作系统中,我们来知道破解密码最常用的手段之一,就是字典暴力破解。我们使用一个简单的脚本,让你的密码每时每刻都在变换,将暴力破解的可能降到最低。即时暴力得到了密码,下一分钟,密码可能就会变掉,破解出来的密码也失去了用处。

基本的原理是,Unix操作系统使用root权限,调用passwd命令,定时修改用户的密码。 但是由于passwd命令比较特殊,要求必须人机交互状态下输入新密码,因此使用一般的方式无法实现完全自动化。

在这里我们使用一个特殊的模块 Expect。他可以模拟人机操作的环境。 (也可以使用linux的 expect 命令完成,但是我们这里主要讨论perl) 密码随时变化,你自己必须要知道当前的密码。这样就要求我们有一套算法。并且有一个随机变化的因子。

例如:我们选取时间为因子。算法为 'password' + 时间的分钟数 ,现在为 11:39 分,那么当前的密码就是 password39 。如果时间是 13:07分,密码就是 password07 。

当然这个是最简单的一个算法,你可以定义自己更复杂的算法。 Unix操作系统代码如下:
 

  1. #!/usr/bin/perluse Expect;   
  2. # 得到时间因子my ($sec,$min,$hour,$mday,$mon,$year)= localtime();   
  3. $mon=$mon+1;if($mon<10){$mon="0".$mon;}if($mday<10){$mday="0".$mday;   
  4. }if($hour<10){$hour="0".$hour;}if($min<10){$min="0".$min;   
  5. }if($sec<10){$sec="0".$sec;}$year=$year+1900;   
  6. # 产生密码my $password = "password".$min;   
  7. # 开始变化密码my $exp = Expect->spawn("passwd root");   
  8. $exp->expect(10,['password: $', sub {my $fh = shift;print $fh "$password";exp_continue;}]);  

将以上代码保存为 /root/passwd.pl Unix操作系统文件,并且给与700 权限(为了安全,不允许其他人读取)

然后在 root 帐户的 crontab 里面加入
* * * * * /root/passwd.pl >/dev/null 2>&1 即可。Unix操作系统中,我们就完成了定时修改unix密码的脚本的讲解。

【编辑推荐】

  1. 简介Unix系统的文件系统
  2. Unix系统中的小知识介绍
  3. 讲解Unix系统的特点的知识
  4. 学习Unix系统经验之谈
  5. Unix系统和最初的 BSD 操作系统
责任编辑:小霞
相关推荐

2010-04-16 14:46:22

2010-04-15 14:40:26

Unix操作系统

2010-04-20 11:34:26

Unix操作系统

2010-04-19 17:25:31

Unix操作系统

2010-04-29 13:30:20

Unix操作系统

2010-05-07 17:41:36

BSD Unix

2010-05-07 13:04:11

Unix Shell

2010-04-16 11:18:23

2010-05-04 17:17:46

Unix类

2010-04-19 16:47:40

Unix操作系统

2010-04-29 17:15:48

Unix操作系统

2010-05-04 14:42:33

Unix操作系统

2010-04-19 14:23:40

Unix操作系统

2010-04-09 15:10:41

Unix操作系统

2010-04-16 16:53:46

Unix操作系统

2010-04-19 17:47:59

Unix操作系统

2010-04-14 10:32:10

Unix操作系统

2010-04-19 17:34:02

Unix操作系统

2010-04-19 15:18:45

Unix操作系统

2010-04-08 16:40:35

点赞
收藏

51CTO技术栈公众号