SOS!!!电脑中病毒~!!求助!在线等!!!

xiaopeng215 2003-09-29 09:52:50
小生电脑不知道怎么回事,E盘无顾被锁住,在我的电脑下点击E盘,出现:是否格式化?
c盘下重装系统,还是没排除故障!!高手指点!!!
...全文
19 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
xiaopeng215 2003-09-30
  • 打赏
  • 举报
回复
不过还是谢谢你们,送分~~`
xiaopeng215 2003-09-30
  • 打赏
  • 举报
回复
你们的意思是我中了逻辑炸弹??????????
icuc88 2003-09-29
  • 打赏
  • 举报
回复
上面的说得很清楚了。

如果你想try try,硬盘里面又没有什么值得留恋的东西了。

不妨重新分区。
aalng 2003-09-29
  • 打赏
  • 举报
回复
硬盘锁住通常是对硬盘的分区表做手脚,因此首先应该了解硬盘的分区表。硬盘分区表位于0柱面0磁头1区,这个扇区的前面200多个字节是主引导程序,后面从01BEH 开始的64个字节是分区表。分区表共64字节,分为4栏,每栏16字节,用来描述一个分区。如果是用DOS的FDISK程序分区后,最多只用两栏,第一栏描述基本的DOS分区,第二栏描述 扩展的DOS分区。
  分区表一栏的结构与各字节的含义如下:
    00H-标志活动字节,活动DOS分区为80H,其它为00H。
    01H-本分区逻辑0扇区所在的磁头号。
    02H-逻辑0扇区所在柱面中的扇区号。
    03H-逻辑0扇区所在的柱面号。
    04H-分区类型标志。
    05H-本分区最后一个扇区的磁头号。
    06H-最后一个扇区的扇区号。
    07H-最后一个柱面的柱面号。
    08H-硬盘上在本分区之前的扇区总数,用双字表示。
    0CH-本分区的扇区总数,从逻辑0扇区计数,不含隐藏扇区,用双字表示。
  在上面的介绍中给出的柱面号与扇区号虽然各占一个字节,但实际上扇区号用6位表示,柱面号用10位表示,扇区号所在字节的最高两位实际上是柱面号的最高两位。
  分区表的最后两个字节是分区表的有效标志,如果将其改变,将不能从硬盘启动,这是一种简单的锁住硬盘的方法。解决的办法是从软盘启动,启动后硬盘仍然可以 使用。用Debug或Noratn中的Diskedit软件将硬盘该分区表中的标志恢复,则从硬盘启动也没有问题了。锁住硬盘的另一种方法是对分区参数做手脚,如果将分区参数全部变为0,则 启动时由于找不到分区参数,从硬盘是没法启动,从软盘启动后也不认硬盘,如果你敲入盘符C并回车,将出现提示Invalid
  driver
  specification。但所幸的是,毕竟可以启动机子,不认硬盘没关系,在A盘上用DOS的Debug仍然可以读出硬盘0柱面0磁头1扇区的内容,修改后再写入0柱面0磁头1扇 区,重新启动机子又没问题了。如果将分区表参数随意改为其它参数,则有可能不能用可以安装DOS的DOS系统盘启动,按F3退出后将出现内存分配错误,不能装载DOS的命令解释 器COMMAND的提示,系统就死机了,笔者就曾碰见过这种情形。但用一张格式化成系统盘的软盘则可以顺利启动,只要有Debug,你仍然可以将分区表参数修改回去。可怕的事情是, 如果你不幸将分区表参数改成一个循环链,即C盘的下一个分区指向D驱,D驱的下一个分区又指向C区,这样循环下去,DOS启动或WIN95启动时由于无休止的读取逻辑驱动器,就只有 死机的份了。这是只要有硬盘存在,不管你用软盘还是硬盘都没法启动机子了,由于不能启动是由于硬盘造成的,即使你将硬盘下到其它计算机上,也没法使用,这样硬盘就彻底被 锁死了,笔者所遭遇就是此情形。不信,你只需将硬盘0柱面0磁头1扇区的1D0H处改为1(如果你的D驱开始柱面号不够大,此处本来就为1),将1D1H处改为0,表示D盘的开始柱面号 跟C盘一样,看看你的计算机还能不能启动,不过你在没有充分的准备前绝不要试。
  一个完整的硬盘锁程序,不过是重新改写0柱面0磁头1扇区的引导程序,并将分区表破坏或故意制造一个循环分区表,而将真正的硬盘分区表参数和引导程序放在其它 隐藏扇区并保护起来,如果启动时口令不对,则不能启动机子,口令对了则顺利启动。这种硬盘锁程序,情形好的还可以用软盘启动;情形严重的就是连软盘也不能启动,硬盘真被 锁住。   三·解开硬盘锁的程序法
  如果硬盘被锁死,是否真的就无法解开呢?当然不是。看看问题的症结所在,根源在于DOS中的IO.SYS文件,它包含LOADER、IO1、IO2、IO3四个模块,其中IO1中包含 有一个很关键的程序SysInt_I,它在启动中很固执,非要去读分区表,而且不把分区表读完誓不罢休。如果碰上分区表是循环的,它就只有死机了。这是DOS的脆弱性和不完备性。其 实这也不能怪DOS,因为DOS为了获得硬盘使用权,就必需读分区表参数,而且DOS还约定驱动器号不能超过26,只不过没有考虑到此等循环分区表情形。一句话,机子不能启动不过是 DOS操作系统造成的,如果另写一个操作系统,或许就能启动机子。当然这只是说个笑话。
  明白了病因在于DOS,问题就好办了。DOS启动中不是要读硬盘分区表吗?我不让你读分区表甚至连硬盘都不让你读,不就可以顺利启动了。的确是这样的,开硬盘锁 的程序实现方法就是基于这个思想形成的。当然,这只有从软盘启动着手了。
  看看计算机的启动过程,上电首先进行的多项硬件自测跟我们没有关系,我们关心的只是它最开始和磁盘打交道时是干什么。如果选择从硬盘启动,则计算机和磁盘 最开始打交道是将硬盘0柱面0磁头1扇区的内容读入内存0000:7C00处并跳到0000:7C00处执行;如果选择从软盘启动,则计算机和磁盘最开始打交道是将A盘0磁道0磁头1扇区的内容 读入内存0000:7C00处并跳到0000:7C00处执行,在执行过程中,计算机并不检查该扇区的内容是什么,只机械地执行读命令,这使得许多系统型病毒得以生存。但利用这一点,恰 恰使我们的程序解锁法有了用武之地。如果我们用DOS格式化一张可以启动机子的系统软盘,将该软盘的0磁道0磁头1扇区的内容移到后面的空白扇区中,而重新写一段程序到该软盘 的0磁道0磁头1扇区,这样用软盘启动时首先执行的是我们所写的程序了。在这段程序中,具备这样一些功能:在DOS启动前抢先拦截INT
  13H,驻留高端内存并监视INT
  13H,判断是否读硬盘,如果是读硬盘就直接返回,这样就禁止了读硬盘,也就避免了DOS读硬盘循环分区表造成的死机;同时拦截对软盘的读取,如果读软盘的0磁道 0磁头1扇区,就改成读真正有引导程序和磁盘参数表的扇区,免得DOS在启动中找不到软盘的磁盘参数表而死机。完成这些任务的同时,还要读取软盘真正的引导程序并把控制权交给 它。
  该方法可以称为万能的,因为它在用软盘启动中,始终不与硬盘打交道,这样不管你硬盘用什么方法加锁了,对DOS的启动都没有影响。当然,这样启动的机子是不认 硬盘的,但这没有关系。你可在机子启动后,用Debug调出驻留高端内存的新INT
  13H程序,将其改为只有一条直接执行旧INT 13H的语句,这样在Debug下可以用INT
  13H读取硬盘0柱面0磁头1扇区的内容,如果你有备份,将分区表参数恢复后再写入0柱面0磁头1扇区,重新启动计算机就可以了。如果实在没有备份,去掉分区表中的 循环链,用正常DOS启动盘重启机子后至少也可以重新对硬盘分区,不至于硬盘被锁住打不开了。
   
  四·程序及说明
    1·下面是写入软盘0磁道0头1扇区的源程序key.com,程序用debug输入。
  C>debug
  -a100
  100 CLI
  101 XOR AX,AX
  103 MOV DS,AX
  105 MOV ES,AX
  107 MOV SS,AX
  109 MOV AX,7C00
  10C MOV SP,AX
  10E STI
  10F MOV SI,AX
  111 MOV DI,7E00
  114 CLD
  115 MOV CX,0200
  118 REPNZ
  119 MOVSB
  11A JMP 0000:7E1F
  11F MOV CX,0003
  122 PUSH CX
  123 MOV AX,0201;读启动软盘的引导扇区
  126 MOV BX,7C00
  129 MOV CX,4F01
  12C MOV DX,0100
  12F INT 13
  131 POP CX
  132 DEC CX
  133 JNZ 0122
  135 MOV AX,[004C];抢先获取INT 13H的位置
  138 MOV [7E88],AX
  13B MOV AX,[004E]
  13E MOV [7E8A],AX
  141 MOV AX,[0413]
  144 DEC AX
  145 MOV [0413],AX
  148 MOV CL,06
  14A SHL AX,CL
  14C MOV ES,AX
  14E XOR AX,AX
  150 MOV DS,AX
  152 MOV SI,7E6D;复制改写的INT 13H程序到高端内存
  155 MOV DI,0000
  158 MOV CX,0030
  15B REPNZ
  015C MOVSB
  015D MOV AX,0000;将新INT 13H位置写入中断向量表
  0160 MOV [004C],AX
  0163 MOV AX,ES
  0165 MOV [004E],AX
  0168 JMP 0000:7C00
  016D PUSHF;新INT 13H程序
  016E CMP DX,0080;是否是硬盘
  0172 JNZ 0176;不是硬盘则继续
  0174 POPF
  0175 IRET;是硬盘则直接返回
  0176 CMP DX,+00;是否读软盘BOOT区?
  0179 JNZ 0186
  017B CMP CX,+01
  017E JNZ 0186
  0180 MOV CX,4F01;是则读79磁道1磁头1扇区
  0183 MOV DX,0100
  0186 POPF
  0187 JMP 0000:0000;此处跳转去执行旧INT 13,
;旧INT 13H的位置由前面程序获得后写入。
  N key.com
  RCX
  200
  W
  Q
  2·程序的装载
    
  在进行下面工作前,先用DOS格式化一张启动的系统盘,并保证没有坏扇区,最好进行启动测试,确保其可以启动机子。由于现在机子上大多只有3寸软驱,因此选 择1.44M的3.5寸软盘。然后用debug
  key.com将程序key.com调入内存偏移地址为100H,同时在400H处写入一段装载程序。即:
  C>debug key.com
  -a400
  400 MOV CX,0003
  403 PUSH CX
  404 MOV AX,0201;将A盘引导程序读入内存1000H处
  407 MOV BX,1000;为确保成功,首次采用重复读3次
  40A MOV CX,0001
  40D MOV DX,0000
  410 INT 13
  412 POP CX
  413 DEC CX
  414 JNZ 0403
  416 MOV AX,0301;将已读入内存的软盘引导程序写入软盘
  419 MOV
glasses1999 2003-09-29
  • 打赏
  • 举报
回复
看样子不象病毒呀,关注。。。。

高手来看看

6,849

社区成员

发帖
与我相关
我的任务
社区描述
Windows 2016/2012/2008/2003/2000/NT
社区管理员
  • Windows Server社区
  • qishine
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧