2017-2018-1 20155319《信息安全技术》实验二——Windows口令破解

2017-2018-1 20155319《信息安全技术》实验二——Windows口令破解

实验环境

  • 试验系统:Windows 2003
  • 实验工具:LC5、SuperDic

实验原理

.口令破解方法

口令破解主要有两种方法:字典破解和暴力破解。

  • 字典破解:是指通过破解者对管理员的了解,猜测其可能使用某些信息作为密码,例如其姓名、生日、电话号码等,同时结合对密码长度的猜测,利用工具来生成密码破解字典。如果相关信息设置准确,字典破解的成功率很高,并且其速度快,因此字典破解是密码破解的首选。
  • 暴力破解:是指对密码可能使用的字符和长度进行设定后(例如限定为所有英文字母和所有数字,长度不超过8),对所有可能的密码组合逐个实验。随着可能字符和可能长度的增加,存在的密码组合数量也会变得非常庞大,因此暴力破解往往需要花费很长的时间,尤其是在密码长度大于10,并且包含各种字符(英文字母、数字和标点符号)的情况下。

.口令破解方式

口令破解主要有两种方式:离线破解和在线破解

离线破解攻击者得到目标主机存放密码的文件后,就可以脱离目标主机,在其他计算机上通过口令破解程序穷举各种可能的口令,如果计算出的新密码与密码文件存放的密码相同,则口令已被破解。可以将口令破解程序的工作流程用图13-1-1来表示。

1.候选口令产生器

候选口令产生器的作用是不断生成可能的口令。有几种方法产生候选口令,一种是用枚举法来构造候选口令(暴力破解),另一种方法是从一个字典文件里读取候选口令(字典破解)。

2.口令加密

口令加密过程就是用加密算法对从口令候选器送来的候选口令进行加密运算而得到密码。这要求加密算法要采用和目标主机一致的加密算法。加密算法有很多种,通常与操作系统的类型和版本相关。

3.口令比较

口令比较就是将从候选口令计算得到的新密码和密码文件中存放的密码相比较。如果一致,那么口令破解成功,可以使用候选口令和对应的账号登录目标主机。如果不一致,则候选口令产生器计算下一个候选口令。
通过在线破解攻击者可以使用一个程序连接到目标主机,不断地尝试各种口令试图登录目标主机。目标主机系统中某些低等级的账号的口令往往容易被尝试成功,然后,攻击者使用其账号进入系统获取密码存放文件(Windows系统是SAM文件,Linux系统是passwd等文件),再使用离线破解方法破解高权限的口令(管理员口令等)。

实验内容

一、字典破解

  • 先设置一个快照在做错的时候可以恢复。

  • 为本机创建新用户。为了达到实验效果,用户口令不要设置得过于复杂,可以选择自己的生日,例如YYYYMMDD。
    右键点击计算机->管理->新用户

  • 进入实验平台,单击工具栏“字典生成器”按钮,启动“字典生成器”。选择“生日”标签页,输入的年份与月份信息应尽量包含上个步骤中用到的生日日期,在“生成字典”标签页中确定字典文件存放的路径以及新用户口令位数,最后生成字典文件。

  • 单击工具栏“LC5”按钮,启动LC5口令破解工具。选择“Session”(会话)|“Session Options…”(会话选项)菜单项,在弹出的“Auditing Options For This Session”对话框中选中“Dictionary Crack”项的“Enabled”,取消其它项的“Enabled”。单击“Dictionary List”(字典列表)按钮,导入步骤(2)中生成的字典文件。

  • 返回LC5主界面,选择“Session”|“Import…”(导入)菜单项,在弹出的“Import”对话框中导入本地用户列表,选择“Session”|“Begin Audit”(开始审计)菜单项,开始字典破解用户口令。

二、暴力破解

(一)

  • 创建新用户,建议用户口令仅由英文字母和数字组成,长度不超过6位,如123abc。
  • 选择LC5的“File”|“New Session…”(新会话)菜单项,新建会话。重新导入本地用户列表。
  • 在会话选项中仅选中“Brute Force Crack”(暴力破解)|“Enabled”,并在“Character Set”(字符集)中选择“alphabet+numbers”(字母表+数字), 开始暴力破解新建用户口令。

(二)

  • 不同密码强度的破解时间比较。再次新建4个用户,使用不同强度的用户口令。
    用户名 密码
    user1 1234
    user2 12abc
用户名 密码
user1 1234
user2 12abc
user3 abc123
user4 12_ab+
  • 新建LC5会话,在会话选项中选中暴力破解选项,字符设置选择“Custom”(自定义)。为了减少破解所需时间,请缩小自定义字符集。
  • 开始暴力破解,当破解完成后,查看LC5的破解信息。

实验中遇到的问题

  • 问题:一开始暴力破解一直无法破解用户4

  • 解决:后来缩小了不必要的字符很快就破解出来了。

    如图:

【思考问题】

1.Windows 7的口令保护文件名称及存储位置是什么?
如图下位置:

2.Windows保护系统帐户口令的算法有LM和NTLM,这两种算法有什么区别?

  • 早期SMB协议在网络上传输明文口令。后来出现"LAN Manager Challenge/Response"
    验证机制,简称LM,它是如此简单以至很容易被破解。微软提出了WindowsNT挑战/响
    应验证机制,称之为NTLM。现在已经有了更新的NTLMv2以及Kerberos验证体系。

3.在密码破解中,常到彩虹表(Rainbow Table),彩虹表是什么?

  • 彩虹表是一个用于加密散列函数逆运算的预先计算好的表, 为破解密码的散列值(或称哈希值、微缩图、摘要、指纹、哈希密文)而准备。一般主流的彩虹表都在100G以上。 这样的表常常用于恢复由有限集字符组成的固定长度的纯文本密码。这是空间/时间替换的典型实践, 比每一次尝试都计算哈希的暴力破解处理时间少而储存空间多,但却比简单的对每条输入散列翻查表的破解方式储存空间少而处理时间多。使用加salt的KDF函数可以使这种攻击难以实现。
  • 参考资料
posted @ 2017-10-26 11:14  20155319任泓霖  阅读(258)  评论(0编辑  收藏  举报