golang生成一个dll供rundll32.exe调用

背景:

项目用例需要覆盖场景:window rundll32.exe 调用dll并写一段内容到磁盘, 开始使用msf生成,会被安全软件拦截,索性用go 写一个
代码如下:

package main
import "C"
import (
"fmt"
"os/exec"
"unsafe"
)
//export MyDllEntryPoint
func MyDllEntryPoint(hwnd int, hinst int, cmdLine *uint16, cmdShow int) int {
cmdline := C.GoString((*C.char)(unsafe.Pointer(cmdLine)))
command := fmt.Sprintf("cmd.exe /c echo rundll32>%s", cmdline)
cmd := exec.Command("cmd.exe", "/c", command)
err := cmd.Run()
if err != nil {
return 0
}
// Return a value to the caller
return 0
}
func main() {
// The main function is required, but it can be empty
}

然后编译为dll

go build -ldflags "-s -w" -buildmode=c-shared -o payload.dll

命令行调用时直接传入要写入的路径如d:\4.txt

C:\Users\yeping01>rundll32.exe D:\code\go_project\src\dll\payload.dll,MyDllEntryPoint d:\\4.txt

执行完后会在d:\4.txt内写入了"rundll32"

posted @   干炸小黄鱼  阅读(114)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示