日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

160 - 51 DueList.6

發(fā)布時(shí)間:2023/12/1 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 160 - 51 DueList.6 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

環(huán)境: Windows xp sp3
工具: Ollydbg exeinfope

0x00 查殼

發(fā)現(xiàn)程序沒(méi)有加殼,那么我們可以直接分析了。

0x01 分析

運(yùn)行程序看一看

看到錯(cuò)誤信息的字符串后我們可以直接搜索了。

可以看到程序會(huì)比較輸入的長(zhǎng)度是否為8位,如果不是就會(huì)彈出錯(cuò)誤的信息,然后再進(jìn)入函數(shù)0040104B檢驗(yàn)輸入的內(nèi)容是否正確。

我們到0040104看一下。

不難看出核心的內(nèi)容主要從 0040106B開(kāi)始,然后進(jìn)入循環(huán),循環(huán)次數(shù)與輸入的內(nèi)容的前4位相關(guān),循環(huán)結(jié)束后判斷exa的值是否滿足要求。

同樣的算法執(zhí)行了兩遍,唯一不同的是eax的初始值和判斷值不同。


這次循環(huán)次數(shù)與輸入內(nèi)容的后4位相關(guān),核心算法還是與上面相同。當(dāng)兩次的檢驗(yàn)均滿足后才會(huì)使得eax返回1,顯示正確的消息框。

0x02 算法分析
程序的核心算法比較簡(jiǎn)單,由于輸入的內(nèi)容是循環(huán)的次數(shù),所以我們可以讓程序反過(guò)來(lái)計(jì)算,并且一直執(zhí)行,直到滿足條件為止,這樣循環(huán)的次數(shù)就是我們應(yīng)該輸入的內(nèi)容了。

unsigned int num1 = 0x36455544;unsigned int temp = 0x4071885;int cl = 1;int ah = 0;int al = 0;int sub = 0;unsigned int sum = 0;while(temp!=num1 || sum==0xDBD76F6){sum++;sub = temp & 0xFF; sub = (sub - cl) & 0xFF; temp = temp & 0xFFFFFF00 | sub; //add al,clah = (temp & 0xFF00) /0x100;al = temp & 0xFF ;ah = ah^al; //xor ah,altemp = (temp&0xFFFF0000)|((ah*0x100)|al);temp = temp >>6 | temp<<26; // rol eax,0x6cl++;if(cl>0xFF){cl = 0;}}

這里是核心算法的第一部分,第二部分不同點(diǎn)只是初始值不同。
注意的是這里有個(gè)判斷sum 是否等于0xDBD76F6,當(dāng)?shù)谝淮悟?yàn)證的循環(huán)次數(shù)為這個(gè)值的時(shí)候,也能使得eax滿足條件,但是顯然這個(gè)值是無(wú)法輸入的,所以我們要忽略掉這個(gè)值。

最后就可以得到:

總結(jié)

以上是生活随笔為你收集整理的160 - 51 DueList.6的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。