麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > ASM > 正文

C# inline-asm / 嵌入x86匯編

2019-11-17 02:13:55
字體:
來源:轉載
供稿:網友
C# inline-asm / 嵌入x86匯編

C#可不可以嵌入匯編 可以 在我眼中C#作為一個介于中上層語言是不可能不可以

置入匯編代碼的 為什么會被我認為中上層語言呢 從C#保留指針就可以看出我知

道有很多人一定不會相信C#可以使用匯編代碼 不過C#會比較麻煩C#不可以直接

內聯匯編(inline-asm)準確的說C#只可以使用(auto-asm)動態匯編 這種技術不是

C#獨有的 易語言、VB、C++ 三種語言都可以 不過動態匯編我見過最多的是被應

用在外掛方面 及遠程匯編注入 實際上是屬于動態匯編技術的一種擴展不過很難

說JIT在編譯代碼后是通過在遠程把匯編代碼寫入托管進程執行的 又或者說是一種

寄生在外殼程序中運行的技術及“內存運行” 懶得討論這些一想到就頭大。

從上圖中你可以看見一份簡單的x86 / call匯編在C#中內嵌并被調用

執行一看你會發現并不是太難 我的一篇博文 寫了一大堆廢話就是說

這個東西不過是易語言的http://blog.csdn.net/u012395622/article/details/46400569

我們知道軟件運行時所有代碼會放在虛擬內存中 而可執行的代碼在內存中

內存保護一般是PAGE_EXECUTE_READ及32不過經過我研究.NET上的

可執行代碼應該是PAGE_EXECUTE_READWIRTE及64 如果是P/invoke

上執行DLL中的保護是32 就可以我們在內嵌匯編時不可以使用只讀保護

如果我們需要使用由.NET去委托去Call那么必須是可讀可寫 如果通過Win32

API去Call那么使用32就可以 有些區別 、我曾研究過易語言上字節集在內存

中的內存保護到底是多少結果與C#是一致 4 / PAGE_READWRITE不過為什

么易語言可以CALL而C#不可以CALL一直是讓我感到較為迷惑的事情 可能是

托管堆與非托管堆之間不同造成的 不過我更希望有大神出來幫忙指點一下下。

由于是X86匯編 首先需要把目標平臺切換為x86 這樣才不會造成C#調用匯編

代碼時出錯 一定不要省略這個步驟

首先你需要定義一個有參數的委托 重點在于在匯編中有這樣一句話

call dWord ptr[ebp+8] // call 參數一

[csharp]view plaincopy
  1. [UnmanagedFunctionPointer(CallingConvention.Cdecl)]
  2. publicdelegateIntPtrCallMethod(IntPtrptr);

由于是在VC下內聯的匯編 最后移植到C# 一般在VC下函數的調用方式是cdcel

何況下面的是按照cdcel導出函數格式進行的 所以不可以使用__stdcall的方式

[csharp]view plaincopy
  1. [STAThread]
  2. staticvoidMain(string[]args)
  3. {
  4. byte[]buf_asm={
  5. //pushebp
  6. //movebp,esp
  7. //subesp,0C0h
  8. //pushebx
  9. //pushesi
  10. //pushedi
  11. //leaedi,[ebp-0C0h]
  12. //movecx,30h
  13. //moveax,0CCCCCCCCh
  14. //repstosdwordptres:[edi]
  15. 85,139,236,129,236,192,0,0,0,83,86,87,141,189,64,
  16. 255,255,255,185,48,0,0,0,184,204,204,204,204,243,171,
  17. //calldwordptr[ebp+8]
  18. 255,85,8,
  19. //popedi
  20. //popesi
  21. //popebx
  22. //movesp,ebp
  23. //popebp
  24. //ret
  25. 95,94,91,139,229,93,195
  26. };
  27. IntPtrptr_asm=SetHandleCount(buf_asm);
  28. VirtualPRotect(ptr_asm,buf_asm.Length);
  29. CallMethodcall_method=Marshal.GetDelegateForFunctionPointer(ptr_asm,typeof(CallMethod))asCallMethod;
  30. call_method(Marshal.GetFunctionPointerForDelegate(newAction(Hello_x86)));
  31. }

首先把你需要嵌入的匯編以字節數組的格式寫出來 然后通過

SetHandleCount函數是用于取地址指針的

[csharp]view plaincopy
  1. staticvoidVirtualProtect(IntPtrptr,intsize)
  2. {
  3. intoutMemProtect;
  4. if(!VirtualProtect(ptr,size,64,outoutMemProtect))
  5. thrownewException("Unabletomodifymemoryprotection.");
  6. }

上面的函數用于修改內存保護 不過是為了讓委托可以進行交互 包括匯編代碼可以被互調用

[csharp]view plaincopy
  1. staticvoidHello_x86()
  2. {
  3. Console.Title=((newStackFrame()).GetMethod()).Name;
  4. Console.WriteLine("Iwasx86assemblycallatestfunction.");
  5. Console.ReadKey(false);
  6. }

上面的函數是一個測試函數 這個函數沒有太大意義 只是表現利用了匯編調用

本函數 然后本函數輸出一個回應的信息 用于提示該函數被寫入內存匯編調用

依賴的外部函數

[csharp]view plaincopy
  1. [DllImport("kernel32.dll",CharSet=CharSet.Auto)]
  2. publicstaticexternIntPtrSetHandleCount(byte[]value);
  3. [DllImport("kernel32.dll",SetLastError=true)]
  4. publicstaticexternboolVirtualProtect(IntPtrlpAddress,intdwSize,intflNewProtect,outintlpflOldProtect);

依賴的命名空間

[csharp]view plaincopy
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 激情视频免费看 | 在线播放一区二区三区 | 在线亚洲播放 | 国产成人精品免费视频大全最热 | 成人福利在线观看 | 久久久久久久久久性 | 亚洲人成在线播放 | 成年人小视频在线观看 | 免费观看视频91 | 水卜樱一区二区av | 在线中文资源免费 | 成人午夜视频免费在线观看 | 国产精品视频专区 | 毛片免费看电影 | 欧洲精品视频在线观看 | 欧美成人一级 | 97porn| 一区二区三区日韩在线观看 | 蜜桃传媒视频麻豆第一区免费观看 | 久久久久久久一区二区 | 久夜草 | 免费观看一级淫片 | 精品一区二区三区中文字幕老牛 | 久久综合久久美利坚合众国 | 久久久成人精品视频 | 欧美成年性h版影视中文字幕 | 色欲香天天天综合网站 | 亚洲一二区视频 | 青热久思思 | 中国大陆高清aⅴ毛片 | 成人三级电影在线 | 91九色蝌蚪国产 | 久久久久久久久久久国产精品 | 一本色道久久99精品综合蜜臀 | 精品三级内地国产在线观看 | 久久久av影视 | 性欧美暴力猛交69hd | 毛片在线免费观看视频 | 免费观看一区 | 国产精品视频不卡 | 久久精品国产精品亚洲 |