如果是硬盘逻辑锁,那就麻烦多了
■修改DOS启动文件
实际上这"逻辑锁"只是利用了DOS在启动时的一个小小缺陷,便令不少高手都束手无策。知道了"逻辑 锁"的"上锁"原理,<-- 正文页网画中画广告 --> <---->
要解锁也就比较容易了,网上介绍的解逻辑锁有不少方法。
普遍采用的是"热拔插"硬盘电源的方法来处理,就是在当系统启动时,先不给被锁的硬盘插上电源线,等待启动完成后再给硬盘"热插"上电源线,这时如果硬盘没有烧坏的话,系统就可以控制硬盘了。但是这是一种比较危险的方法,比较容易烧毁硬盘或者主板,为了保险起见,小编采用了另外的方法,修改DOS启动文件。
首先准备一张DOS系统盘,带上debug、pctools5.0、fdisk等工具。然后在另一台机器上,使用个人比较熟悉的二进制编辑工具如“debug、pctools5.0,或者windows下的ultraedit”等都可以,修改软盘上的IO.SYS文件,需要注意的是修改前要把该文件的属性改为正常,具体方法是在这个文件里面搜索第一个"55aa"字符串,找到以后修改为任何其他数值即可。用这张修改过的系统软盘你就可以顺利地带着被锁的硬盘启动了。
■解锁2板斧
不过这时由于该硬盘正常的分区表已经被程序给恶意修改了,我们无法用FDISK来删除和修改分区,而且仍无法用正常的启动盘启动系统,这时我们可以用DEBUG来手工 <---->
恢复。使用DEBUG手工修复硬盘步骤如下:
a:\>debug
-a
-xxxx:100 mov ax,0201 读一个扇区的内容
-xxxx:103 mov bx,500 设置一个缓存地址
-xxxx:106 mov cx,0001 设置第一个硬盘的硬盘指针
-xxxx:109 mov dx,0080 读零磁头
-xxxx:10c int 13 硬盘中断
-xxxx:10e int 20
-xxxx:0110 退出程序返回到指示符
-g 运行
-d500 查看运行后500地址的内容
这时候会发现地址6be开始的内容是硬盘分区的信息,发现此硬盘的扩展分区指向自己,这就使DOS或WINDOWS启动时查找硬盘逻辑盘进去死循环,在DEBUG指示符下用E命令修改内存数据 具体如下:
E6BE
xx.0 xx.0 xx.0……………
………………………..
…………………..55 AA
55 AA表示硬盘有效的标记,不要修改,xx0表示把以前的数据"xx"改成0
再用硬盘中断13把修改好的数据写入硬盘就可以了,具体如下:
A:\>debug
a 100 表示修改100地址的汇编指令
-xxxx:100 mov ax,0301 写硬盘一个扇区
-xxxx: 这里直接按回车
-g 运行
-q 退出
然后运行 FDISK/MBR重置硬盘引导扇区的引导程序,再重新启动电脑一切OK,顺利的进入了熟悉的XP界面,并且硬盘上的数据全部都在,没有丢失。这是一个比较简单的方法并且能够保存硬盘里的数据,同时小编还查到了另外的几个方法,这里和大家一起分享一下。如果我们不需要保数据的话,还有更加简单的处理方法。