请问在C/C++内联汇编中JNE/JMP等跳转指令要怎么实现啊?

AiXed 2010-11-12 12:07:35
例如一段代码:

ULONG MyZwOpenLife( IN ULONG ObjName,IN ULONG ObjAddr)
{
_asm
{
push ebp
mov ebp, esp
mov eax, dword ptr [<&ntoskrnl.NtBuildNumber>] //F6C170DC 这里要怎么实现呢
mov ax, word ptr [eax]
xor edi, edi
JNE _CodeOne //这里写错了
retn 8
_CodeOne:
push 43
cmp eax, 29A
retn 12


...全文
838 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
xiaohuh421 2010-11-12
  • 打赏
  • 举报
回复
mov eax, dword ptr [<&ntoskrnl.NtBuildNumber>] //F6C170DC 这里要怎么实现呢

都知道地址了,就直接写地址就行了.
mov eax,0xF6C170DC
赵4老师 2010-11-12
  • 打赏
  • 举报
回复

HANDLE hLib;
hLib = LoadLibrary ("ntoskrnl.exe");
PFNDLL pNtBuildNumber=(PFNDLL) GetProcAddress(hLib,"NtBuildNumber");

ULONG MyZwOpenLife( IN ULONG ObjName,IN ULONG ObjAddr)
{
_asm
{
push ebp
mov ebp, esp
mov eax, pNtBuildNumber//dword ptr [<&ntoskrnl.NtBuildNumber>] //F6C170DC 这里要怎么实现呢
mov ax, word ptr [eax]
xor edi, edi
JNE _CodeOne //这里写错了
retn 8
}
_CodeOne:
_asm {
push 43
cmp eax, 29A
retn 12
}
AiXed 2010-11-12
  • 打赏
  • 举报
回复
地址是会变动的
要怎么索引

65,210

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧