登录注册
社区应用 最新帖子 精华区 社区服务 会员列表 统计排行
主题 : [ZT]我和电脑亲密接触的心路历程
伍胥之 离线
级别: 军区司令员

显示用户信息 
40楼  发表于: 2011-01-23   
解密生涯
从LQ电脑拿到那本《磁盘机加密原理》后,又让我读得入迷了。 VK^m]??s_  
t}f,j^`e  
感觉过去加密盘的东西,一下子弄明白了。 tZ_D.syBAc  
G q2@37U  
1. 额外的磁道:5吋盘正常是40道,0-39,但是所有的软驱都可以读写第41道,42就不可靠了。3.5吋盘是80道,但是都可以读写82道,83就极不可靠了。因此,有些程序会将部分数据写在标准磁道外(实际上0道是最外圈,额外的都在最内部)。 U6LENY+Ja  
xcE<|0N :  
2. 非标准扇区:正常的扇区都是512字节,用代码02表示,但是也可以格式化为1024、2048、256etc,甚至可以将整条磁道格式化为只有一个超级大的扇区(太大了读错的机会会更大)。这也是一种常用的方式。 0z`-fQfK  
|HA1.Y=  
3.道缝/扇缝加密:这应该是软盘加密的终极方案。实际上没有道缝,因为步进电机是固定的。它都本质上都是扇缝。当格式化时,需要提供一个DAP表,表示了格化化条件参数,每道多少扇区,每扇区多大。格式化时,每条磁道上的所有扇区都是定长的。诀窍在于:每个扇区还有自己的参数表需要写入扇区数据区前面的信息块,这里面的数据包括[道号、面号、扇区号],还有一个最特别的数据是扇区长度。不是都是定长吗?为何还需要这个?怪就怪在这里!这个扇区实际大小是在磁道参数表中固定的,但是在扇区信息块中这个值是可以任意填写的。读这个扇区时,必须提供跟这个信息块完全相同的数据块,否则“Sector not found”会等着你。 所以这种加密方式是:格式化时在磁道参数表中提供了一个标准数据,但在扇区信息块中却给出了一个不同的数据。e.q. DAP中声明02(512字节),但是扇区信息块中却声明为03(1024字节)。当读该扇区时,如果指定用02读,扇区找不到,如果用03读,可以读出1024字节,可是实际上只有512啊!于是乎,它读出了下一扇区的信息块,所以会100%地出现CRC校验错误。这就是它的原理。 ,2 Q5'!o  
#;F*rJ[XY  
磁道的真正格式如下: d\j[O9W>  
,O 1/|Y  
Sect1 信息区[标志-同步信息[n个F6]-CRC校验值]--扇区数据区[标志-同步信息[n个F6]-数据开始标志-数据区[2^n 格式化为F6]-CRC校验值]-Sect2[....] ---Sect n[.....] Zo T8  
^y<8 &ZFH  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
41楼  发表于: 2011-01-23   
终极解决方案:INT 0E d9.~W5^fC  
_REAzxe S  
如果明白了这个机理,用汇编写个程序就可以轻易而举地破解了。 ja+PVf  
th`pf   
江民杀毒的DOS版都是用这种方式加密的。金山毒霸DOS版也是这样。 N7mYE  
M|}V6F_y  
INT 0Eh是一个硬件中断,只为软驱操作服务。只要是软盘操作,最后都会产生这个中断通知系统操作结束。 G?5Vj_n  
I9O%/^5^[w  
所以,可以写一个INT 0Eh的服务程序,记录所以的非标准软盘操作。记下它的位置,保留在内存中某个地方(该中断响应过程中不可以进行磁盘操作,最好也不要调用任何DOS功能,否则可能会引起重入)。 KU*XRZu)  
p\ _&  
所以,当里的DOS杀毒出一个版本我就可以破解一个版本。不论是什么加密办法。把程序复制到硬盘运行,它一定会读钥匙盘,记录下来所有的非标准操作。不用修改程序,也不必跟踪它。然后根据钥匙盘的磁盘参数,在标准格式化完成后,再用自己的格式化程序,格式化出一条跟钥匙盘一样的磁道。也就是说,自己配钥匙盘。 bDT@E,cSi  
$Lt'xW`8  
我用这种办法,复制出很多盘给朋友。可惜那时没有经济送脑,否则可以自己卖这种盗版盘了。 8m 5T  
3&KRG}5  
当KV2000Q版出现后,我突然觉得这技术上没有新意,就不玩了。也不再给他们解密了。除非是我自己用。 LV`tnt's  
HAdDr!/`  
9UE)4*5  
u/(~ew I  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
42楼  发表于: 2011-01-23   
硬盘加密 9 y{R_  
],l\HHQ  
软盘结构比较简单,编程也简单。所有的软驱都是在端口级兼容的。 pra0:oHN  
pRGag~h|E  
硬盘则不同,每个厂家都有自己的特别东西,所以访问硬盘只能通过INT 13h。这就限制了加密的方法。 NM0s*s42  
{Xv0=P  
我见过的方法很少,一种是写在DOS分区外的某个地方一点东西。另一种是在安装时记录个别文件在盘上的物理位置。因为复制文件到硬盘时,OS根据当前盘上空余情况,选一个地方存这个文件。所以不同的机器上两个文件在同一个地方的概率为无穷小。所以它可以写一个文件,把它标记成隐藏与系统。这样就不比担心磁盘整理程序把它搬家。 U~q2j#pJ  
'QC'*Hl  
解密方法也简单,记录文件的物理位置,再复制时,检测一下该位置是否已被占用,如果被占用,把文件搬开。把那个特殊文件写入硬盘的指定位置,然后修改目录与FAT。 W>y &  
ZFNg+H/k  
这个方法,比破解文件本身的算法要简单。
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
43楼  发表于: 2011-01-25   
这个坑是前几天在武汉期间没啥事填的。 {YF(6wVl  
KK, t!a  
我知道,其实多数同学都不太懂我写了些啥,因为太老了。 BKk+<#Ti  
pI1IDu*_Z  
主要是人老了,有怀旧情结。 xt1Ug~5  
G?<uw RV  
总结一下自己不务正业的过程,给部分同学一点点教训。 v^3s?V D  
FG)(,?q  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
44楼  发表于: 2011-01-27   
认识C语言
日子不咸不淡地过着,我也不紧不慢地玩着。 Mew,g:m:  
U%rq(`;  
参加工作两年后,我教过的第一届学生中的一个,读研到了我所在的实验室。他是个很聪明的学生,跟我也很谈得来。 !v<` ^`x9I  
Ox9M![fC  
他有一天下课后,把他自己上计算机课的课本带到了实验室---C语言。 g+3_ $qIQ+  
usR+ZQaA  
我拿起来顺手一翻,发现这个东东对初学者来说是太难了,但是我觉得很有趣。 e3,@prr  
P` AW8Y6o  
把工作丢到一边,坐下专心致志地看一半个下午,看出味道来了,因为有汇编的基础,所以理解C的东西还是非常容易的。到了下班时间,仍然舍不得放下。于是拿回家接着看,居然看上瘾了,没有吃晚饭,也不睡觉了。到天亮的时候刚好看完。 <7_s'UAL!  
 EHk$,bM  
我居然连续读了18个小时! dry>TXG*  
tui5?\  
再回到实验室,找来学生装上Turbo C 2.0,就开始下手编程序了。而且TC2.0 有非常好的联机帮助系统,需要啥函数看看说明就可以了。 ti!kJ"q  
Q$b4\n?44  
那个学生也非常聪明,我用电脑的时候,他就在旁边看,也不用问啥问题,我们随意地边聊边写程序。到最后,凡是我在电脑上用过的东东,他自己都学会了。 uSUog+i  
VWrb` p@  
我们一起写了几个程序,把他上的生物统计学课程的各种检验方法都分别写出了一个个程序。据说,十多年后,我们学院的部分学生仍然用那个程序进行显著性检验。 NK6 ~qWsu  
$;Z0CG  
qi$nG_<<Z  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
45楼  发表于: 2011-03-03   
VB+Win32 API sGG q~7  
{LBL8sG  
ASP
杺栫杣杊椌柮栬,䒴蓉艿芖。
清水 离线
级别: 军长
显示用户信息 
46楼  发表于: 2011-03-03   
引用
引用第46楼伍胥之于03-03-2011 14:21发表的  : =R*IOJ  
VB+Win32 API p-*{x  
NIHcX6Nw  
ASP Wr`<bLq1vs  
5xQ5)B4k  
介个真的看不懂。 +mN8uU~(kx  
你说你老啦,喜欢怀旧了,才想起来填坑。 mQ3gp&d3W  
提醒我也想想,是不是也老啦,是不是也有坑没填呢。
伍胥之 离线
级别: 军区司令员

显示用户信息 
47楼  发表于: 2012-04-16   
又有点想学ASP.NET了。谁可以教我啊?
杺栫杣杊椌柮栬,䒴蓉艿芖。
newport93 离线
级别: 资深会员
显示用户信息 
48楼  发表于: 2012-04-16   
Re:认识C语言
引用
引用第45楼伍胥之于01-27-2011 08:12发表的 认识C语言 : 1$^r@rP  
日子不咸不淡地过着,我也不紧不慢地玩着。 uo(LZUjPbN  
UID`3X  
参加工作两年后,我教过的第一届学生中的一个,读研到了我所在的实验室。他是个很聪明的学生,跟我也很谈得来。 wk'&n^_br  
jvpv1>KYV  
他有一天下课后,把他自己上计算机课的课本带到了实验室---C语言。 "U$](k.<VA  
....... %* RZxR):  
o_5[}d  
能搞得定C,还怕什么?网上很多sample, 看看你应该就会了吧。
随遇而安, 知足常乐。
伍胥之 离线
级别: 军区司令员

显示用户信息 
49楼  发表于: 2015-08-29   

杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
50楼  发表于: 2015-08-29   

UMT}2d%  
B\l0kiNT  
当年闲得无聊,用DEBUG跟踪出来FDISK居然有一个未公开的参数,就信手写了个小豆腐,发在来浪潮集团的一个小杂志上。 PWquu`  
-Owb@Nw  
没想到,第二年有个专业人士居然在另一杂志上发表了一篇差不多一样一样的文章。 ]z| 2  
] mK{E~Zll  
这是不是叫所见略同呢?
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
51楼  发表于: 2015-08-29   
玩硬盘主引导记录,写动态分区表 9[lk=1.qN  
oq b(w+<  
DOS玩了一阵,再玩点啥呢? [HQ/MkP-Z  
!lA~;F  
那就看看硬盘分区表吧! J,s:CBCGL  
NRspi_&4J  
那个时代办公室用的电脑也就是PC-XT,好一点是286,毕竟不是专业用嘛!能打个字就差不多了。 %b~ND?nn-  
J aJ/ |N  
没有杂志看,也没有攻略,没有目的,就是瞎琢磨。 @gmo;8?k  
_a_T`fE&de  
一般几十MB的硬盘,都是CHS模式,连LBA都没有。 ~-uDN)  
&7\fj  
0道0面一共有17个扇区,最多1023条磁道。 DL为驱动器,80h为第一硬盘, DS:BX为读写缓冲,AH=2(r)/3(w), CH为10位磁道的低8位,AL低6位是扇区号,高2位借给CH,所以最大为1023, DH是磁头号,最大倒是可以到255。CL是读写扇区数,缓冲区应该是不能超过64KB. 那个时候支持的最大磁盘为 1024道* 256面 /道* 63扇区/面.   I|;C} lfp  
YPO24_B  
Mov DL, 80h `.]oH1\  
Mov DH,00 B|{E[]iK  
mov BX, 1000h ^t$uDQ[hA  
mov cx, 0001 CkNh3'<wg  
mov ax,0201h M a3}w-=;  
int 13h dxH .  
W@zu N)U  
这就把主引导记录读入了地址为DS:1000h的内存。 h##U=`x3  
MmFtG-  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
52楼  发表于: 2015-08-29   
U(nassembly) 1000 n-,mC /4  
把它反汇编出来,就知道它在启动过程中在做什么了。 :@@m'zF<;  
2OqEyXh  
不过,不能真正跟踪它,只在在脑子里或纸上跟踪,否则立马死机。 %;<g!Vw.k  
txQr|\4k  
因为,执行不了几步,它就把它自己搬到了一个固定的地方0000:0700H这个地方在有OS时是OS的核心地区。 B@ ms Gb C  
.CNwuN\  
BOIS是固定把这个主引导程序读到0:700H地方,检查这个块的最后一个字是否是0xAA55的。然后才将控制权给它。 i CB:p  
W1ndb:  
它干得活很简单,它把自己复制到另一个地址,并跳过去,检查分区表,一共4*20h的个符,每一项用32个字节,标志了是否可引导,OS类型、分区大小、起始的CHS位置。然后找到一个标记为80h的可引导分区,从对应的CHS读出这个分区的引导记录,也是读 到0:700h,检查合格后就再交给它了。 Lf%}\0:  
Vock19P  
那个时候,我只用过DOS,别的系统从没有用过。 mHJGpJ=a-  
P :%b[7  
ub+XgNO  
但是,我突然发现这4个分区不够用的了。 5fz K*[B  
&5G@YQD1e  
因为我需要隐藏点什么,当然,不是艳照,那时不仅没有DC,连扫描仪也没有。 (uC@cVk P  
/x_AWnU  
cm q4w&x/  
->7zVAX  
}9!}T~NMs  
'q RQO(9&m  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
53楼  发表于: 2015-08-29   
地址记错了,不是0:700h,而是0:7c00h
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
54楼  发表于: 2015-08-29   
0000:7C00 XOR AX,AX 4X+I2C D  
0000:7C02 MOV SS,AX <'7s3  
0000:7C04 MOV SP,7C00 v!$?;"d+  
0000:7C07 STI 7W5Cm\  
0000:7C08 PUSH AX !\O!Du  
0000:7C09 POP ES -lAY*2Jg  
0000:7C0A PUSH AX   N[v=;&  
0000:7C0B POP DS 7KJ0>0~Et  
0000:7C0C CLD 7r.~L  
0000:7C0D MOV SI,7C1B G)_Zls2 ;  
0000:7C10 MOV DI,061B m}S}fH(  
0000:7C13 PUSH AX L]&y[/\E1  
0000:7C14 PUSH DI <(V~eo e  
0000:7C15 MOV CX,01E5   :_=YH+bZ  
0000:7C18 REPZ   e"*ho [  
0000:7C19 MOVSB PSX o"   
0000:7C1A RETF WT3g31  
yNU}1_oK  
;跳到这里来了。 y9=<q%Kc-  
0000:061B MOV SI,07BE 4^d).{&X  
0000:061E MOV CL,04 " SP6o  
0000:0620 CMP [SI],CH ; )r)ZmS5O  
0000:0622 JL 062D   VWzuV&;P  
0000:0624 JNZ 063B   0;`+e22  
0000:0626 ADD SI,+10 \w(0k^<7  
0000:0629 LOOP 0620 qZv@ULluc  
0000:062B INT 18  ‘ 如果没有可引导的分区,就直接执行一个软中断,这个玩艺,当年叫ROM BASIC #hMkajG  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
55楼  发表于: 2015-08-29   
我想干什么呢? fL]jk1.Xv-  
$H]NC-\+>  
办公室有很多人,我想把游戏、我的个人文件分别放到不同分区上,给每个人定义一个属于自己的分区。 iun_z$I<+Z  
>.G#\w  
那年头没有什么安全机制啊!所以只能是隐藏整个磁盘。 BN FYUcVP  
8pp;" "b  
我用整整一个扇区做分区表,最多可以分成16个分区(我的硬盘才20MB!)。 3 f~znO  
dO,; k +  
然后用另一个扇区做成一个用户表,反正第一个分区总是从0道的1柱面开始,有十几个扇区在DOS分区之前可用呢!用户表里面定义了用户名、密码和用户可以访问的分区,除大家共用的C盘有DOS外,其它的15个根据权限决定哪一个可以访问。如果在0-15分区中,0,1,5,6,7可被该用户访问,则把0分区变成DOS的主分区,把1567合成一个扩展分区,1为D盘567分别有EFG盘。而对另一用户而言,可能D代表了第9个分区。 ?5,I`9  
/^bU8E&^M  
在引导过程中,主引导记录不含分区表,除了有一个55AA标志外,其余是我自己的代码。加载我的全部代码后,要求用户输入一个用户名、密码,如果校验成功,则根据相应权限,重新合成一个用户对应的分区表,包括了主分区和扩展分区(以及逻辑卷的链表)。 tDfHO1pS  
uY/C iTWr  
然后,根据新生成的分区表,去引导主分区的DOS分区。 )UVekkq>Q  
XD_!5+\H1  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
56楼  发表于: 2015-08-29   
还需要一个安装程序,把我们东东直接写到CH0Head0Sect1中。 bw+IH-b  
mG0_&'"YIG  
这些代码都是用汇编写的,不过,我已经会用C了,所以它的管理程序是用C写出来的。就是定义用户表、分区表这样的东东,把它写入一个Binary的文件中。 w*o2lg9  
|zd5P  
居然可以工作了!虽然长得很丑,而且一点也不温油。 v\?l+-A? y  
4mpcI  
我不知道那个时候有没有多操作系统引导程序,所以,我这个也没有多OS,所以我自己给它起了一个名字,叫动态引导。
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
57楼  发表于: 2015-08-29   
很可惜,这些代码我已经找不到了。
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
58楼  发表于: 2015-08-29   
引用
引用第28楼newport93于01-21-2011 17:06发表的  : R| Uu  
老5从FORTRAN玩起的啊,那是相当的牛! r)Ml-r =  
pEX Q  
现在玩什么了?   4%JJ} {Ff  
u),.q7(m  
T, PN6d  
现在只会玩VB6.0混合点Win32API了。 &0J8I Cd=  
6BEDk!  
不过ASP用得多一点,我的课基本上都自己弄个网站,让学生交作业或考试。 D>Rlm,U  
o& $lik  
想学学ASPX, 但是我对.net的托管啥得不明白。 k5+ Fxf  
,pQ[e$u1  
杺栫杣杊椌柮栬,䒴蓉艿芖。
伍胥之 离线
级别: 军区司令员

显示用户信息 
59楼  发表于: 2015-08-29   
Re:回 38楼(伍胥之) 的帖子
引用
引用第39楼suehan234于01-22-2011 08:00发表的 回 38楼(伍胥之) 的帖子 : F"3'~ 6  
佩服,玩也玩得这么专业! c+8 Y|GB  
F6:LH,~8   
,6"[vb#*3  
算不上专业,只是瞎捣鼓,或瞎鼓捣。
杺栫杣杊椌柮栬,䒴蓉艿芖。
描述
快速回复

验证问题:
3 * 6 = ? 正确答案:18
按"Ctrl+Enter"直接提交