开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 233|回复: 24
收起左侧

[易语言] 求个程序注入DLL并分配内存空间写入参数例子

[复制链接]
结帖率:75% (3/4)
发表于 13 小时前 | 显示全部楼层 |阅读模式   安徽省滁州市
20精币
新人在研究内存脚本,遇到远程调用CALL程序崩溃的问题,大佬给的提议是在目标进程中注入DLL并分配内存空间写入自己需要的参数,然后停止主线程调用DLL里面的参数,调用完成后恢复主线程。根据大佬给的C的代码,研究了几天,用易语言编写DLL注入主程序并且分配空间,一直提示分配内存失败。用的是精易模块的申请内存。有没有哪位大佬给个完整的例子!!


回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值无答案申请取消悬赏投诉有答案未采纳为最佳

签到天数: 12 天

发表于 13 小时前 | 显示全部楼层   北京市北京市
还没研究出来?注释写的很详尽了啊  给钱的话可以给你写一份
回复

使用道具 举报

结帖率:75% (3/4)

签到天数: 15 天

 楼主| 发表于 12 小时前 | 显示全部楼层   安徽省滁州市
萧楚楠 发表于 2025-6-17 10:51
还没研究出来?注释写的很详尽了啊  给钱的话可以给你写一份

可以的,加Q私聊
回复

使用道具 举报

结帖率:50% (1/2)

签到天数: 17 天

发表于 11 小时前 | 显示全部楼层   广西壮族自治区崇左市
这种不用注入DLL那么麻烦
回复

使用道具 举报

签到天数: 17 天

发表于 11 小时前 | 显示全部楼层   广东省广州市
用大漠AsmCall,在hwnd所在的线程调用与分配内存,不行再加绑定 dx.public.memory或者开启内存盾,除非有检测,否则都可以过。
回复

使用道具 举报

结帖率:75% (3/4)

签到天数: 15 天

 楼主| 发表于 11 小时前 | 显示全部楼层   安徽省滁州市
baitso 发表于 2025-6-17 12:19
用大漠AsmCall,在hwnd所在的线程调用与分配内存,不行再加绑定 dx.public.memory或者开启内存盾,除非有检 ...

大漠的都已经试过了,就是有检测运行一会就出错崩溃,远程CALL,挂接主线程调用CALL都不行。
回复

使用道具 举报

结帖率:73% (8/11)

签到天数: 5 天

发表于 10 小时前 | 显示全部楼层   河南省郑州市
你没有提供代码,但是大致是以下四种原因导致:
1.权限不足:未启用SeDebugPrivilege权限,导致无法操作目标进程内存
2.32/64位进程冲突,若目标进程为64位,32位注入器需使用VirtualAllocEx而非普通内存申请
3.内存保护属性错误:未设置PAGE_READWRITE权限导致写入失败
4.参数传递错误:文本型参数未转换为指针传递(需用取变量数据地址()或指针到文本())。
========================================================
1.DLL侧代码(被注入部分)
.版本 2
.程序集 程序集1

.子程序 远程调用函数, 整数型, 公开
.参数 参数指针, 整数型
    ' 从指针还原数据
    〖参数1〗 = 指针到文本 (参数指针)  ' [1]()
    ' 执行核心操作(此处演示弹窗)
    信息框 (〖参数1〗, 0, , )
    返回 0

2.注入器侧代码(关键API封装)
.版本 2
.程序集 窗口程序集_启动窗口
.DLL命令 VirtualAllocEx, 整数型, "kernel32.dll",  "VirtualAllocEx"
    .参数 进程句柄, 整数型
    .参数 地址, 整数型
    .参数 大小, 整数型
    .参数 类型, 整数型    '  MEM_COMMIT=4096
    .参数 保护, 整数型    '  PAGE_READWRITE=4
.DLL命令 WriteProcessMemory, 整数型, "kernel32.dll",  "WriteProcessMemory"
    .参数 进程句柄, 整数型
    .参数 基地址, 整数型
    .参数 缓冲区, 整数型
    .参数 大小, 整数型
    .参数 实际写入, 整数型, 传址
.DLL命令 SuspendThread, 整数型, "kernel32.dll",  "SuspendThread"
    .参数 线程句柄, 整数型

3.内存分配与调用流程
.子程序 注入并调用
.参数 目标进程ID, 整数型
.局部变量 进程句柄, 整数型
.局部变量 内存地址, 整数型
.局部变量 参数数据, 文本型
.局部变量 线程ID, 整数型

' ① 提权并打开进程
进程句柄 = OpenProcess (2035711, 假, 目标进程ID)  ' PROCESS_ALL_ACCESS [2]()
' ② 在目标进程分配内存
内存地址 = VirtualAllocEx (进程句柄, 0, 1024, 4096, 4)  ' 分配1KB可读写内存
.如果真 (内存地址 = 0)
    信息框 (“内存分配失败!错误码:” + 取错误信息 (), 0, , )
    返回
.如果真结束

' ③ 写入参数数据
参数数据 = “需要传递的字符串”
WriteProcessMemory (进程句柄, 内存地址, 取变量数据地址 (参数数据), 取文本长度 (参数数据), 0)

' ④ 挂起主线程
线程句柄 = 取主线程句柄 (目标进程ID)  ' 需自定义此函数
SuspendThread (线程句柄)

' ⑤ 注入DLL并调用函数
DLL路径 = “C:\demo.dll ”
DLL句柄 = 远程注入DLL (目标进程ID, DLL路径)  ' 精易模块的“DLL注入”
调用函数地址 = GetProcAddress (DLL句柄, “远程调用函数”)
创建远程线程 (进程句柄, 0, 0, 调用函数地址, 内存地址, 0, 0)

' ⑥ 恢复线程
ResumeThread (线程句柄)
CloseHandle (进程句柄)

权限提权代码-必须项
.子程序 提权
.局部变量 令牌, 整数型
OpenProcessToken (-1, 40, 令牌)
LookupPrivilegeValueA (0, “SeDebugPrivilege”, 0)
AdjustTokenPrivileges (令牌, 假, 0, 0, 0, 0)

精易模块替代方案
若内存_申请失败,改用以下API组合:内存地址 = VirtualAllocEx_ (进程句柄, 0, 大小, 4096, 4)  [2]()

跨进程文本传递规范
文本型参数必须通过WriteProcessMemory写入目标进程空间
DLL内用指针到文本()还原数据

正确使用进程级内存API和线程冻结时机控制
回复

使用道具 举报

结帖率:75% (3/4)

签到天数: 15 天

 楼主| 发表于 8 小时前 | 显示全部楼层   安徽省滁州市
LLXXLL 发表于 2025-6-17 12:14
这种不用注入DLL那么麻烦

用什么方法呢,主程序有检测,CRC、堆栈、行为、全部试过了,并不是这几种检测。出错崩溃的代码是内存访问违例。运行的功能CALL都是正常的,代码肯定是没问题的。
回复

使用道具 举报

签到天数: 12 天

发表于 8 小时前 | 显示全部楼层   北京市北京市
wanglong1 发表于 2025-6-17 12:36
大漠的都已经试过了,就是有检测运行一会就出错崩溃,远程CALL,挂接主线程调用CALL都不行。 ...

挂接主线程调用已经不行了你还研究什么
回复

使用道具 举报

结帖率:50% (1/2)

签到天数: 17 天

发表于 8 小时前 | 显示全部楼层   广西壮族自治区崇左市
wanglong1 发表于 2025-6-17 14:53
用什么方法呢,主程序有检测,CRC、堆栈、行为、全部试过了,并不是这几种检测。出错崩溃的代码是内存访 ...

游戏崩还是进程崩?
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表