史萊姆論壇

返回   史萊姆論壇 > 專業主討論區 > 程式語言討論區
忘記密碼?
論壇說明

歡迎您來到『史萊姆論壇』 ^___^

您目前正以訪客的身份瀏覽本論壇,訪客所擁有的權限將受到限制,您可以瀏覽本論壇大部份的版區與文章,但您將無法參與任何討論或是使用私人訊息與其他會員交流。若您希望擁有完整的使用權限,請註冊成為我們的一份子,註冊的程序十分簡單、快速,而且最重要的是--註冊是完全免費的!

請點擊這裡:『註冊成為我們的一份子!』

Google 提供的廣告


發文 回覆
 
主題工具 顯示模式
舊 2009-03-29, 02:58 PM   #1 (permalink)
管理版主
 
mini 的頭像
榮譽勳章
UID - 4144
在線等級: 級別:98 | 在線時長:10174小時 | 升級還需:23小時級別:98 | 在線時長:10174小時 | 升級還需:23小時級別:98 | 在線時長:10174小時 | 升級還需:23小時級別:98 | 在線時長:10174小時 | 升級還需:23小時級別:98 | 在線時長:10174小時 | 升級還需:23小時級別:98 | 在線時長:10174小時 | 升級還需:23小時級別:98 | 在線時長:10174小時 | 升級還需:23小時級別:98 | 在線時長:10174小時 | 升級還需:23小時
註冊日期: 2002-12-07
文章: 13495
精華: 0
現金: 26860 金幣
資產: 3024790 金幣
預設

在 win api 裡有兩個可用指令
ReadProcessMemory 與 WriteProcessMemory

VB範例:
如何掃描外部程式的記憶體
http://sunh.hosp.ncku.edu.tw/~cww/html/q00534.html

如何讀寫外部程式的記憶體
http://sunh.hosp.ncku.edu.tw/~cww/html/q00486.html
mini 目前離線  
送花文章: 2055, 收花文章: 8070 篇, 收花: 26924 次
回覆時引用此帖
有 2 位會員向 mini 送花:
eric10104 (2009-04-02),Living (2009-04-04)
感謝您發表一篇好文章
舊 2009-03-29, 09:38 PM   #2 (permalink)
註冊會員
榮譽勳章

勳章總數
UID - 320197
在線等級: 級別:1 | 在線時長:6小時 | 升級還需:6小時
註冊日期: 2009-03-14
文章: 7
精華: 0
現金: 13 金幣
資產: 13 金幣
預設

謝謝mini 板大回覆

小弟對win api 不是很熟悉 , 試問板大幾個簡易問題 , 幾個簡單問題 , 請別介意 ,

直接使用VB , 參照網址內的語法下去撰寫?

有些記憶體位置我不明白該如何加入 , 小弟不是本科系 , 對C語言認知只有一些 ,

不太明白有些動作該如何去執行 , 有勞 mini 板大幫忙 , 謝謝.
eric10104 目前離線  
送花文章: 2, 收花文章: 6 篇, 收花: 6 次
回覆時引用此帖
向 eric10104 送花的會員:
Living (2009-04-04)
感謝您發表一篇好文章
舊 2009-03-30, 08:03 PM   #3 (permalink)
管理版主
 
mini 的頭像
榮譽勳章
UID - 4144
在線等級: 級別:98 | 在線時長:10174小時 | 升級還需:23小時級別:98 | 在線時長:10174小時 | 升級還需:23小時級別:98 | 在線時長:10174小時 | 升級還需:23小時級別:98 | 在線時長:10174小時 | 升級還需:23小時級別:98 | 在線時長:10174小時 | 升級還需:23小時級別:98 | 在線時長:10174小時 | 升級還需:23小時級別:98 | 在線時長:10174小時 | 升級還需:23小時級別:98 | 在線時長:10174小時 | 升級還需:23小時
註冊日期: 2002-12-07
文章: 13495
精華: 0
現金: 26860 金幣
資產: 3024790 金幣
預設

引用:
作者: eric10104 查看文章
謝謝mini 板大回覆

小弟對win api 不是很熟悉 , 試問板大幾個簡易問題 , 幾個簡單問題 , 請別介意 ,

直接使用VB , 參照網址內的語法下去撰寫?

有些記憶體位置我不明白該如何加入 , 小弟不是本科系 , 對C語言認知只有一些 ,

不太明白有些動作該如何去執行 , 有勞 mini 板大幫忙 , 謝謝.
他都寫得很清楚
Read/WriteProcessMemory(ByVal hProcess As Long, lpBaseAddress As Any, lpBuffer As Any, ByVal nSize As Long, lpNumberOfBytesWritten As Long) As Long
所以 lpBaseAddress: 這是要讀取或是寫入的基底位址
就是 記憶體位置

Win API 不是只有 VB能用
C/C++ 要用的話是以引入 .h檔方式

不熟程式語言的話
基本上還是建議你用工具去改
像個人都用 GameMaster
mini 目前離線  
送花文章: 2055, 收花文章: 8070 篇, 收花: 26924 次
回覆時引用此帖
向 mini 送花的會員:
Living (2009-04-04)
感謝您發表一篇好文章
舊 2009-03-31, 04:19 PM   #4 (permalink)
註冊會員
榮譽勳章

勳章總數
UID - 320197
在線等級: 級別:1 | 在線時長:6小時 | 升級還需:6小時
註冊日期: 2009-03-14
文章: 7
精華: 0
現金: 13 金幣
資產: 13 金幣
預設

貌似這種? 原始碼是在外國論壇詢問的 , 他向我說明用 C++ 可以用您講的

WriteProcessMemory 直接 寫 Value 落 "Address"

程式語言這方面不是很懂 , 我也是以 FPE 和 GM8修改 , 因為這款遊戲目前 Bug 還很多
, 想編譯這款修改器 , 幫助更多人







#include <windows.h> // add the windows.h

HANDLE g_hProcess;
DWORD g_arList; // Fill the address you want
int iVal; // Fill the value you want

BOOL WriteMemory(DWORD dwAddr, DWORD dwValue)
{
return ::WriteProcessMemory(g_hProcess, (LPVOID)dwAddr, &dwValue, sizeof(DWORD), NULL);
}

int main()
{
char szFileName[] = "target.exe";
STARTUPINFO si = {sizeof(si)};
PROCESS_INFORMATION pi;
::CreateProcess(NULL, szFileName, NULL, NULL, FALSE, CREATE_NEW_CONSOLE, NULL, NULL, &si, π);
::CloseHandle(pi.Thread);
g_hProcess = pi.Process;
if(WriteMemory(g_arList, iVal))
printf("Write data Sucess!\n");
::CloseHandle(g_hProcess);
return 0;
}
eric10104 目前離線  
送花文章: 2, 收花文章: 6 篇, 收花: 6 次
回覆時引用此帖
向 eric10104 送花的會員:
Living (2009-04-04)
感謝您發表一篇好文章
發文 回覆



發表規則
不可以發文
不可以回覆主題
不可以上傳附加檔案
不可以編輯您的文章

論壇啟用 BB 語法
論壇啟用 表情符號
論壇啟用 [IMG] 語法
論壇禁用 HTML 語法
Trackbacks are 禁用
Pingbacks are 禁用
Refbacks are 禁用


所有時間均為台北時間。現在的時間是 02:36 AM


Powered by vBulletin® 版本 3.6.8
版權所有 ©2000 - 2025, Jelsoft Enterprises Ltd.


SEO by vBSEO 3.6.1