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"
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)