欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

記逆向小白的第一次vbsedit 9爆破及內(nèi)存補(bǔ)丁制作過程

 更新時(shí)間:2021年04月21日 14:44:06   作者:patanka  
這篇文章主要介紹了記逆向小白的第一次vbsedit 9爆破及內(nèi)存補(bǔ)丁制作過程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

作為一個(gè)搞破解、逆向的小白,第一發(fā)文,請各位大神多指教。

近期需要批量處理一些word和excel文檔,開始一直用word的宏,但是發(fā)給同事用的時(shí)候同事老是不會(huì)啊。后來就想寫一些VBS的腳本,讓他們直接雙擊運(yùn)行就好了??墒菍慥BS腳本也需要調(diào)試的呀,沒有合適的工具很惱火的。于是上網(wǎng)找到了VBSEdit這么個(gè)工具,可是非注冊版每次調(diào)試都會(huì)彈出一個(gè)提示框,等好多秒,找破解版要么版本太老,要么就是夾帶私貨的。于是就想自己動(dòng)手試一下好了。

下載了x64dbg,啟動(dòng),打開vbsedit.exe。點(diǎn)擊Start Debugging 的按鈕,彈出了注冊對(duì)話框。

有點(diǎn)懵。不知從何入手。于是就各種搜啊搜啊,最后決定從找對(duì)話框開始,搜索跨模塊調(diào)用,輸入“dialog”,出現(xiàn)了五個(gè)相關(guān)的調(diào)用:

于是在第一項(xiàng)處下斷點(diǎn),重新跟到這里后發(fā)現(xiàn)是從1401087B4這一行運(yùn)行來的,于是在這一行下斷點(diǎn)。

再次跟進(jìn)來,停下后在右下角的棧區(qū)會(huì)看到對(duì)這個(gè)的調(diào)用來自vbsedit.00000000140107C8E,再轉(zhuǎn)到這個(gè)調(diào)用點(diǎn)。

然后在從這個(gè)調(diào)用點(diǎn)往后追溯,就這樣追溯幾次調(diào)用后就會(huì)找到一個(gè)貌似調(diào)用注冊對(duì)話的地方:

就這個(gè)Call <vbsedit.#所有對(duì)話框>調(diào)用(當(dāng)然后面的注釋都是我跟的時(shí)候自己加的),先試試NOP掉它。

再次運(yùn)行,注冊對(duì)話框不彈了。再試了試其他功能,一切正常。成功!

同樣的方法,可以把單步調(diào)試等彈注冊對(duì)話框的地方都找到,同樣nop掉。啟動(dòng)的注冊對(duì)話框有一個(gè)JNE的判斷,改成JE就好了。

然后就是修補(bǔ)文件,另存了exe。再次運(yùn)行打了補(bǔ)丁的文件,結(jié)果一閃而過,程序運(yùn)行不了啦。

原來這程序有自校驗(yàn),一個(gè)字節(jié)都不能改,改了就不能正常運(yùn)行。要么是沒法正常退出,要么是沒有語法高亮,總之各種不正常。

怎么辦呢?繼續(xù)破自校驗(yàn)? 算了,對(duì)我這個(gè)小白來說這個(gè)難度有點(diǎn)太大了。

考慮到用x64dbg打開直接在內(nèi)存修改后可以正常運(yùn)行,應(yīng)該說找的爆破位置還是對(duì)的,所以如果打個(gè)內(nèi)存補(bǔ)丁應(yīng)該是可行的。

內(nèi)存補(bǔ)丁怎么弄呢?沒整過耶,于是又是搜啊搜啊,找到了用Dll劫持注入打補(bǔ)丁的方法。

試了試常用的version.dll,發(fā)現(xiàn)這個(gè)dll是可以利用的。接下來就是需要自己寫一個(gè)version.dll用來劫持并打內(nèi)存補(bǔ)丁啦。

祭出了AheadLib這個(gè)工具,選擇簡單的直接轉(zhuǎn)發(fā)函數(shù),生成了version.cpp。

然后在入口函數(shù)里加上自己打補(bǔ)丁的代碼就好了,代碼如下:(小白水平,勿噴)

#include <Windows.h>
#include <stdio.h>
 
// 導(dǎo)出函數(shù)
#pragma comment(linker, "/EXPORT:GetFileVersionInfoA=c:\\windows\\system32\\version.dll.GetFileVersionInfoA,@1")
#pragma comment(linker, "/EXPORT:GetFileVersionInfoByHandle=c:\\windows\\system32\\version.dll.GetFileVersionInfoByHandle,@2")
#pragma comment(linker, "/EXPORT:GetFileVersionInfoExA=c:\\windows\\system32\\version.dll.GetFileVersionInfoExA,@3")
#pragma comment(linker, "/EXPORT:GetFileVersionInfoExW=c:\\windows\\system32\\version.dll.GetFileVersionInfoExW,@4")
#pragma comment(linker, "/EXPORT:GetFileVersionInfoSizeA=c:\\windows\\system32\\version.dll.GetFileVersionInfoSizeA,@5")
#pragma comment(linker, "/EXPORT:GetFileVersionInfoSizeExA=c:\\windows\\system32\\version.dll.GetFileVersionInfoSizeExA,@6")
#pragma comment(linker, "/EXPORT:GetFileVersionInfoSizeExW=c:\\windows\\system32\\version.dll.GetFileVersionInfoSizeExW,@7")
#pragma comment(linker, "/EXPORT:GetFileVersionInfoSizeW=c:\\windows\\system32\\version.dll.GetFileVersionInfoSizeW,@8")
#pragma comment(linker, "/EXPORT:GetFileVersionInfoW=c:\\windows\\system32\\version.dll.GetFileVersionInfoW,@9")
#pragma comment(linker, "/EXPORT:VerFindFileA=c:\\windows\\system32\\version.dll.VerFindFileA,@10")
#pragma comment(linker, "/EXPORT:VerFindFileW=c:\\windows\\system32\\version.dll.VerFindFileW,@11")
#pragma comment(linker, "/EXPORT:VerInstallFileA=c:\\windows\\system32\\version.dll.VerInstallFileA,@12")
#pragma comment(linker, "/EXPORT:VerInstallFileW=c:\\windows\\system32\\version.dll.VerInstallFileW,@13")
#pragma comment(linker, "/EXPORT:VerLanguageNameA=c:\\windows\\system32\\version.dll.VerLanguageNameA,@14")
#pragma comment(linker, "/EXPORT:VerLanguageNameW=c:\\windows\\system32\\version.dll.VerLanguageNameW,@15")
#pragma comment(linker, "/EXPORT:VerQueryValueA=c:\\windows\\system32\\version.dll.VerQueryValueA,@16")
#pragma comment(linker, "/EXPORT:VerQueryValueW=c:\\windows\\system32\\version.dll.VerQueryValueW,@17")
 
 
//宏 Debug("format string",arg1,arg2,...)
//用于Debug調(diào)試信息輸出,用法同 printf
#ifdef _DEBUG
#define Debug(...) DllPrintf(__VA_ARGS__) 
#else
#define Debug(...) 
#endif
 
int DllPrintf(char *fmt,...)
{
	//dll調(diào)試時(shí)打開控制臺(tái)窗口顯示調(diào)試信息
	//用法同printf
 
	va_list argptr;
	va_start(argptr,fmt);
	char buffer[512] ={0};
	int cnt = vsprintf_s(buffer,fmt,argptr);
	va_end(argptr);
 
	static HANDLE ghConsole = INVALID_HANDLE_VALUE;
	if(INVALID_HANDLE_VALUE == ghConsole)
	{
		AllocConsole();
		ghConsole = GetStdHandle(STD_OUTPUT_HANDLE);
	}
	DWORD dw;
	WriteConsole(ghConsole ,buffer,(DWORD)strlen(buffer),&dw,NULL);
	return cnt;
}
 
void Patch(void)
{
	DWORD dwProcessId;
	dwProcessId = GetCurrentProcessId();
 
	HANDLE hProcess;
	hProcess = OpenProcess(PROCESS_ALL_ACCESS,false,dwProcessId);
	if(hProcess == 0){
		Debug("open process error \n");
	}else
	{
		Debug("the hProcess is : %x\n",(INT)hProcess);
	}
 
	LPVOID lpAddressStart,lpAddressDebug,lpAddressDebugStep;
 
	lpAddressStart=(LPVOID)0x000000014009147F;//啟動(dòng)注冊框的爆破地址
	lpAddressDebug=(LPVOID)0x00000001400E3ED7;//debug對(duì)話框的爆破地址
	lpAddressDebugStep=(LPVOID)0x00000001400DA343;//debug step over對(duì)話框的爆破地址
 
	char je=0x74;//je指令
	SIZE_T dwNumberOfBytesRead;
	dwNumberOfBytesRead=0;
 
	if(WriteProcessMemory(hProcess,lpAddressStart,&je,sizeof(je),&dwNumberOfBytesRead))
	{
		Debug("%d byte writed,start dialog patch ok!\n ",dwNumberOfBytesRead);
	}else
	{
		Debug("read error:%d \n", GetLastError());
 
	}
 
 
	unsigned char temp[5]={0x90,0x90,0x90,0x90,0x90};
 
	if(WriteProcessMemory(hProcess,lpAddressDebug,&temp,sizeof(temp),&dwNumberOfBytesRead))
	{
		Debug("%d byte writed,debug dialog patch ok!",dwNumberOfBytesRead);
	}else
	{
		Debug("read error:%d \n", GetLastError());
 
	}
 
 
	if(WriteProcessMemory(hProcess,lpAddressDebugStep,&temp,sizeof(temp),&dwNumberOfBytesRead))
	{
		Debug("%d byte writed,debug step over dialog patch ok!",dwNumberOfBytesRead);
	}else
	{
		Debug("read error:%d \n", GetLastError());
 
	}
 
	CloseHandle(hProcess);
}
 
// 入口函數(shù)
BOOL WINAPI DllMain(HMODULE hModule, DWORD dwReason, PVOID pvReserved)
{
	if (dwReason == DLL_PROCESS_ATTACH)
	{
		DisableThreadLibraryCalls(hModule);
 
		Patch();
 
	}
	else if (dwReason == DLL_PROCESS_DETACH)
	{
	}
 
	return TRUE;
}

代碼很簡單,有個(gè)地方我犯過錯(cuò)誤,這里記錄一下:

導(dǎo)出函數(shù)的#pragma comment(linker, "/EXPORT:GetFileVersionInfoA=c:\\windows\\system32\\version.dll.GetFileVersionInfoA,@1") 其中 c:\\windows\\system32\\version.dll這個(gè)地方,這是用于64位程序的,所以是這個(gè)路徑。也可以寫成改名后的dll文件名,比如你把原version.dll文件改成了oldversion.dll,那么就寫成#pragma comment(linker, "/EXPORT:GetFileVersionInfoA=oldversion.dll.GetFileVersionInfoA,@1") 就可以了。不過這樣你需要把oldversion.dll 同樣拷貝到vbsedit.exe的同目錄。如果是我的寫法就只需要把生成的version.dll拷貝到vbsedit.exe程序目錄就行了。

另外dll在控制臺(tái)輸出調(diào)試信息的方法我也是找了好久,開始一直用MessageBox,很痛苦的。

爆破地址只能適用于vbsedit 9.1226版本。

生成的version.dll拷貝到VBSEdit.exe的同目錄即可。

再次運(yùn)行,這次沒有了注冊提示框。打開幾個(gè)vbs文件,試了試編輯、調(diào)試等功能,測試一切正常,成功!

總結(jié):破解逆向好像也沒那么難,呵呵! 我也行 ^_^

到此這篇關(guān)于記逆向小白的第一次vbsedit 9爆破及內(nèi)存補(bǔ)丁制作的文章就介紹到這了,更多相關(guān)vbsedit 9爆破及內(nèi)存補(bǔ)丁內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++解析ini文件的實(shí)現(xiàn)方法

    C++解析ini文件的實(shí)現(xiàn)方法

    在C++編程中,有時(shí)我們需要處理配置文件來存儲(chǔ)應(yīng)用程序的設(shè)置和參數(shù),而INI文件是一種常見的選擇,這篇文章主要給大家介紹了關(guān)于C++解析ini文件的實(shí)現(xiàn)方法,需要的朋友可以參考下
    2024-08-08
  • C++之Boost::array用法簡介

    C++之Boost::array用法簡介

    這篇文章主要介紹了C++之Boost::array用法簡介,較為詳細(xì)的分析了Boost::array中的常見用法,并用實(shí)例的形式予以總結(jié)歸納,需要的朋友可以參考下
    2014-10-10
  • C語言中的BYTE和char深入解析

    C語言中的BYTE和char深入解析

    在C語言中,字符(character)這個(gè)術(shù)語具有兩個(gè)層次上的含義:書寫源程序的字符和程序處理的字符
    2013-10-10
  • C++使用opencv調(diào)用級(jí)聯(lián)分類器來識(shí)別目標(biāo)物體的詳細(xì)流程

    C++使用opencv調(diào)用級(jí)聯(lián)分類器來識(shí)別目標(biāo)物體的詳細(xì)流程

    所謂級(jí)聯(lián)分類器其實(shí)就是把分類器按照一定的順序聯(lián)合到一起,下面這篇文章主要給大家介紹了關(guān)于C++使用opencv調(diào)用級(jí)聯(lián)分類器來識(shí)別目標(biāo)物體的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-05-05
  • C++?typedef常見用法詳解

    C++?typedef常見用法詳解

    這篇文章主要介紹了C++?typedef用法詳解,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-03-03
  • OpenCV實(shí)現(xiàn)智能視頻監(jiān)控

    OpenCV實(shí)現(xiàn)智能視頻監(jiān)控

    這篇文章主要為大家詳細(xì)介紹了OpenCV實(shí)現(xiàn)智能視頻監(jiān)控,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • C++實(shí)現(xiàn)圖書館管理系統(tǒng)源碼

    C++實(shí)現(xiàn)圖書館管理系統(tǒng)源碼

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)圖書館管理系統(tǒng)源碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • C++中fork函數(shù)的使用及原理

    C++中fork函數(shù)的使用及原理

    這篇文章主要介紹了C++中fork函數(shù)的使用及原理,在C++中,fork函數(shù)用于創(chuàng)建一個(gè)新的進(jìn)程稱為子進(jìn)程,該進(jìn)程與原始進(jìn)程幾乎完全相同,需要的朋友可以參考下
    2023-05-05
  • C語言線性表全面梳理操作方法

    C語言線性表全面梳理操作方法

    線性表,數(shù)據(jù)結(jié)構(gòu)中最簡單的一種存儲(chǔ)結(jié)構(gòu),專門用于存儲(chǔ)邏輯關(guān)系為"一對(duì)一"的數(shù)據(jù)。線性表是基于數(shù)據(jù)在實(shí)際物理空間中的存儲(chǔ)狀態(tài),又可細(xì)分為順序表(順序存儲(chǔ)結(jié)構(gòu))和鏈表
    2022-04-04
  • C語言代碼實(shí)現(xiàn)簡單2048游戲

    C語言代碼實(shí)現(xiàn)簡單2048游戲

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)2048游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-12-12

最新評(píng)論