首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何用汇编语言在Windows注册表中设置值?

如何用汇编语言在Windows注册表中设置值?
EN

Stack Overflow用户
提问于 2013-07-29 04:59:54
回答 2查看 2.1K关注 0票数 0

好的。所以我有一个程序,它试图在Windows注册表中创建一个值。不幸的是,什么都没发生。我一直在试图弄清楚这些参数中是否有错误。以下是代码:

代码语言:javascript
复制
 includelib \Masm64\Lib\Kernel32.lib
 includelib \Masm64\Lib\Advapi32.lib
 extern RegOpenKeyExA : proc
 extern RegSetValueExA : proc
 extern ExitProcess : proc

 dseg       segment     para 'DATA'
 vlnm       db          'Startup', 0
 sbky       db          'Software\Microsoft\Windows\CurrentVersion\Run', 0
 phkr       dd          0
 path       db          'C:\Users\School\AppData\Roaming\Startups.exe', 0
 dseg       ends

 cseg       segment     para 'CODE'
 start      proc
            lea         rdx, [phkr]
            push        rdx
            sub         rsp, 28h
            mov         r9d, 2
            xor         r8d, r8d
            lea         rdx, [sbky]
            mov         ecx, 80000001h
            call        RegOpenKeyExA

            add         rsp, 28h
            push        45
            lea         rbx, [path]
            push        rbx
            sub         rsp, 28h
            mov         r9d, 1
            xor         r8d, r8d
            lea         rdx, [vlnm]
            mov         ecx, phkr
            call        RegSetValueExA

            call        ExitProcess
start       endp
cseg        ends
            end

有什么建议吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-08-03 01:33:11

请允许我回答我自己的问题。这个问题并不真正涉及不正确的参数,而是我分配堆栈空间的一个错误。虽然期望我为rcx、rdx、r8和r9分配20h的堆栈空间,并在16字节的边界上对齐返回地址,但我错误地创建了一个模板,如下所示:

代码语言:javascript
复制
*empty*         (rsp-8)
param2          (rsp-16)
param1          (rsp-24)
*empty*         (rsp-32... causes incorrect parameters and convention!)
space for r9    (rsp-40)
space for r8    (rsp-48)
space for rdx   (rsp-56)
space for rcx   (rsp-64)
return address  (rsp-72... not on a 16-byte boundary!)

正确的模板是

代码语言:javascript
复制
*empty*         (rsp-8)
param2          (rsp-16)
param1          (rsp-24)
space for r9    (rsp-32)
space for r8    (rsp-40)
space for rdx   (rsp-48)
space for rcx   (rsp-56)
return address  (rsp-64)

在RegSetValueEx调用之前,我无意中在堆栈参数和寄存器参数之间分配了8个字节,从而提供了一个不正确的参数。以下是正确的代码:

代码语言:javascript
复制
includelib \Masm64\Lib\Kernel32.lib
includelib \Masm64\Lib\Advapi32.lib
extern RegOpenKeyExA : proc
extern RegSetValueExA : proc
extern ExitProcess : proc

dseg        segment     para 'DATA'
vlnm        db          'Startup', 0
sbky        db          'Software\Microsoft\Windows\CurrentVersion\Run', 0
phkr        dd          0
path        db          'C:\Users\Games\AppData\Roaming\Startups.exe', 0
dseg        ends

cseg        segment     para 'CODE'
start       proc
            lea         rdx, [phky]
            push        rdx
            sub         rsp, 20h
            mov         r9d, 2
            xor         r8d, r8d
            lea         rdx, [sbky]
            mov         ecx, 80000001h
            call        RegOpenKeyExA

            add         rsp, 20h
            push        44
            lea         rbx, [path]
            push        rbx
            sub         rsp, 20h
            mov         r9d, 1
            xor         r8, r8
            lea         rdx, [vlnm]
            mov         ecx, phkr
            call        RegSetValueExA

fini:       call        ExitProcess
start       endp
cseg        ends
            end

干杯!

票数 2
EN

Stack Overflow用户

发布于 2013-07-29 06:46:13

您只为您的密钥(phkr dw 0)分配两个字节。在我看来,它至少应该是4个字节。

此外,我建议您添加一些错误检查。如果失败,RegOpenKeyExRegSetValueEx都会返回非零错误代码。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17916348

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档