奇跡mu游戲服務(wù)器[GS修改]添加擴(kuò)展DLL的方法

奇跡mu游戲服務(wù)器[GS修改]添加擴(kuò)展DLL的方法
?

我是艾西,今天的內(nèi)容對于懂技術(shù)的朋友可以作為參考
不是技術(shù)的技術(shù)0050A260 .[GS修改]添加擴(kuò)展DLL的方法:
68 6C737005 PUSH gameserv.0570736C0050A265 .
68 746D6800 PUSH gameserv.00686D74 ;ASCII "1.02.05"0050A26A .
6A 00 PUSH 00050A26C . 8A0D 48549A06 MOV CL,BYTE PTR DS:[69A5448]0050A272 . 51 PUSH ECX0050A273 . 8B15 70549A06 MOV EDX,DWORD PTR DS:[69A5470]0050A279 . 52 PUSH EDX0050A27A . B9 C852D806 MOV ECX,gameserv.06D852C80050A27F . E8 DF91EFFF CALL gameserv.00403463裝載文件完畢后開始正式啟動的時候加0050A284 . E8 771D0A00 CALL gameserv.005AC000 這里我們自己添加的,直接跳轉(zhuǎn)的添加DLL的代碼005AC000 /$ 68 40C05A00 PUSH gameserv.005AC040 ; /FileName = "PNProc.dll"\\005AC040= "PNProc.dll"\\其他的類同005AC005 |. E8 4274FCFF CALL <JMP.&;KERNEL32.LoadLibraryA> ; \LoadLibraryA005AC00A |. 09C0 OR EAX,EAX005AC00C |. 0F84 9B000000 JE gameserv.005AC0AD005AC012 |. 68 50C05A00 PUSH gameserv.005AC050 ; /ProcNameOrOrdinal = "PNLoadProc"005AC017 |. 50 PUSH EAX ; |hModule005AC018 |. E8 2974FCFF CALL <JMP.&;KERNEL32.GetProcAddress> ; \GetProcAddress\\這個就是獲取DLL中函數(shù)的API\\我的函數(shù)名字為PNLoadProc005AC01D |. A3 60C15A00 MOV DWORD PTR DS:[5AC160],EAX005AC022 |. 09C0 OR EAX,EAX005AC024 |. 0F84 83000000 JE gameserv.005AC0AD005AC02A |. EB 65 JMP SHORT gameserv.005AC091 \\
這里跳轉(zhuǎn)到下面對DLL進(jìn)行處理...005AC091 |> \6A 30 PUSH 30 ; /Style = MB_OK|MB_ICONEXCLAMATION|MB_APPLMODAL005AC093 |. 68 D0C05A00 PUSH gameserv.005AC0D0 ; |Title = "文件加載完成..."005AC098 |. 68 F0C05A00 PUSH gameserv.005AC0F0 ; |Text = "PNProc.dll加載完成,正在進(jìn)行其它裝載..."005AC09D |. 6A 00 PUSH 0 ; |hOwner = NULL005AC09F |. FF15 1082D906 CALL DWORD PTR DS:[<&;USER32.MessageBoxA>>; \MessageBoxA005AC0A5 |. A1 60C15A00 MOV EAX,DWORD PTR DS:[5AC160]005AC0AA |. FFD0 CALL EAX \\正式調(diào)用DLL中函數(shù)005AC0AC |. C3 RETN005AC0AD |> 6A 10 PUSH 10 ; /Style = MB_OK|MB_ICONHAND|MB_APPLMODAL005AC0AF |. 68 20C15A00 PUSH gameserv.005AC120 ; |Title = "發(fā)生錯誤!"005AC0B4 |. 68 30C15A00 PUSH gameserv.005AC130 ; |Text = "PNProc.dll加載出錯,程序不能正常運行..."005AC0B9 |. 6A 00 PUSH 0 ; |hOwner = NULL005AC0BB |. FF15 1082D906 CALL DWORD PTR DS:[<&;USER32.MessageBoxA>>; \MessageBoxA005AC0C1 \. C3 RETN