开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 189|回复: 0
收起左侧

[易语言] 易语言在win 2022服务器上调用闪退

[复制链接]
结帖率:84% (21/25)
发表于 6 天前 | 显示全部楼层 |阅读模式   江苏省徐州市
13精币
A:主程序中控台 》易语言exeB:DLL 数据通信 》易语言DLL
C:第三方服务端 》被操作的服务端


在本地电脑,使用 主程序 把 DLL注入> 服务端
远程注入的方式,然后远程调用函数,本地电脑可以正常执行。win11

换到云服务器第三方服务端就崩溃,经过排查,只要执行 远程调用函数 服务端就会崩溃闪退。
这种情况怎么办。


经过测试DLL 与主程序,里面的所有功能单独拿出来,在云服务器都能正常运行,且不会报错。
出问题的就在 远程调用函数调用后服务端崩溃  但是这个功能在本地电脑就没有任何问题。

  
子程序名返回值类型公开备 注
远程注入_调用函数逻辑型 
参数名类 型参考可空数组备 注
进程ID整数型
函数名文本型DLL命令所在动态链接库中的名称
参数一字节集DLL命令参数,使用命令"到字节集()"转换,非整数参数则不能为4字节!
参数二字节集
参数三字节集
参数四字节集
参数五字节集
参数六字节集
变量名类 型静态数组备 注
临时内存地址1整数型 
临时内存地址2整数型 
GetProcAddress地址整数型 
汇编代码1字节集 
汇编代码2字节集 
函数地址整数型 
长度整数型 
指针地址整数型 
参数整数型0
i整数型 
返回值整数型 
' 打开进程
进程句柄 = OpenProcess ( #PROCESS_ALL_ACCESS, 假, 进程ID)
' 申请内存
临时内存地址1 = VirtualAllocEx (进程句柄, 0, 取文本长度 (函数名), #MEM_COMMIT, #PAGE_READWRITE )
如果真 (临时内存地址1 = 0)
CloseHandle (进程句柄)
返回 ()
' 将函数名写入申请的内存
WriteProcessMemory (进程句柄, 临时内存地址1, 到字节集 (函数名), 取文本长度 (函数名), 0)
' 获取GetProcAddress在Kernel32.dll中的地址
GetProcAddress地址 = GetProcAddress (GetModuleHandleA (“Kernel32.dll”), “GetProcAddress”)
调试输出 (DLL句柄)
' 代码含义:执行GetProcAddress函数,参数一是DLL句柄,参数二是临时内存地址(函数名)
汇编代码1 = { 184 }到字节集 (GetProcAddress地址){ 104 }到字节集 (临时内存地址1){ 104 }到字节集 (DLL句柄){ 255, 208, 195, 144 }
' mov eax,GetModuleHandleA地址
' push 临时内存地址
' push DLL句柄
' call eax
' ret
' nop
' 申请内存
临时内存地址2 = VirtualAllocEx (进程句柄, 0, 取字节集长度 (汇编代码1), #MEM_COMMIT, #PAGE_READWRITE )
如果真 (临时内存地址1 = 0)
VirtualFreeEx (进程句柄, 临时内存地址1, 0, #MEM_RELEASE )
CloseHandle (进程句柄)
返回 ()

' 将汇编代码1写入申请的内存
WriteProcessMemory (进程句柄, 临时内存地址2, 汇编代码1, 取字节集长度 (汇编代码1), 0)
' 创建远程线程执行汇编代码
线程句柄 = CreateRemoteThread (进程句柄, 0, 0, 临时内存地址2, 0, 0, 0)
如果真 (线程句柄 = 0)
VirtualFreeEx (进程句柄, 临时内存地址1, 0, #MEM_RELEASE )
VirtualFreeEx (进程句柄, 临时内存地址2, 0, #MEM_RELEASE )
CloseHandle (进程句柄)
返回 ()
WaitForSingleObject (线程句柄, #DMUS_SEG_REPEAT_INFINITE )
' 获取函数地址
GetExitCodeThread (线程句柄, 函数地址)
' 释放申请的内存,关闭线程句柄
VirtualFreeEx (进程句柄, 临时内存地址1, 0, #MEM_RELEASE )
VirtualFreeEx (进程句柄, 临时内存地址2, 0, #MEM_RELEASE )
CloseHandle (线程句柄)
如果真 (函数地址 = 0)
CloseHandle (进程句柄)
返回 ()
' 将参数写入内存中
如果真 (参数一 ≠ {  })
长度 = 取字节集长度 (参数一)
如果 (长度 = 4)
指针地址 = 取字节集数据 (参数一, #整数型, )
指针地址 = VirtualAllocEx (进程句柄, 0, 长度, #MEM_COMMIT, #PAGE_READWRITE )
WriteProcessMemory (进程句柄, 指针地址, 参数一, 长度, 0)
加入成员 (参数, 指针地址)
如果真 (参数二 ≠ {  })
长度 = 取字节集长度 (参数二)
如果 (长度 = 4)
指针地址 = 取字节集数据 (参数二, #整数型, )
指针地址 = VirtualAllocEx (进程句柄, 0, 长度, #MEM_COMMIT, #PAGE_READWRITE )
WriteProcessMemory (进程句柄, 指针地址, 参数二, 长度, 0)
加入成员 (参数, 指针地址)
如果真 (参数三 ≠ {  })
长度 = 取字节集长度 (参数三)
如果 (长度 = 4)
指针地址 = 取字节集数据 (参数三, #整数型, )
指针地址 = VirtualAllocEx (进程句柄, 0, 长度, #MEM_COMMIT, #PAGE_READWRITE )
WriteProcessMemory (进程句柄, 指针地址, 参数三, 长度, 0)
加入成员 (参数, 指针地址)
如果真 (参数四 ≠ {  })
长度 = 取字节集长度 (参数四)
如果 (长度 = 4)
指针地址 = 取字节集数据 (参数四, #整数型, )
指针地址 = VirtualAllocEx (进程句柄, 0, 长度, #MEM_COMMIT, #PAGE_READWRITE )
WriteProcessMemory (进程句柄, 指针地址, 参数四, 长度, 0)
加入成员 (参数, 指针地址)
如果真 (参数五 ≠ {  })
长度 = 取字节集长度 (参数五)
如果 (长度 = 4)
指针地址 = 取字节集数据 (参数五, #整数型, )
指针地址 = VirtualAllocEx (进程句柄, 0, 长度, #MEM_COMMIT, #PAGE_READWRITE )
WriteProcessMemory (进程句柄, 指针地址, 参数五, 长度, 0)
加入成员 (参数, 指针地址)
如果真 (参数六 ≠ {  })
长度 = 取字节集长度 (参数六)
如果 (长度 = 4)
指针地址 = 取字节集数据 (参数六, #整数型, )
指针地址 = VirtualAllocEx (进程句柄, 0, 长度, #MEM_COMMIT, #PAGE_READWRITE )
WriteProcessMemory (进程句柄, 指针地址, 参数六, 长度, 0)
加入成员 (参数, 指针地址)






' 代码含义:执行函数,参数。。。。
汇编代码2 = { 184 }到字节集 (函数地址)
变量循环首 (取数组成员数 (参数), 1, -1, i)  ' 参数是倒着排的
汇编代码2 = 汇编代码2 + { 104 }到字节集 (参数 [i])
变量循环尾 ()
汇编代码2 = 汇编代码2 + { 255, 208, 195, 144 }
' mov eax,函数地址
' push 参数XXX
' push 参数XXX
' push 参数XXX
' ......
' call eax
' ret
' nop
' 申请内存
指针地址 = VirtualAllocEx (进程句柄, 0, 取字节集长度 (汇编代码2), #MEM_COMMIT, #PAGE_READWRITE )
' 将汇编代码2写入申请的内存
WriteProcessMemory (进程句柄, 指针地址, 汇编代码2, 取字节集长度 (汇编代码2), 0)
' 方便释放内存
加入成员 (参数, 指针地址)
' 创建远程线程执行汇编代码
线程句柄 = CreateRemoteThread (进程句柄, 0, 0, 指针地址, 0, 0, 0)
如果真 (线程句柄 = 0)
计次循环首 (取数组成员数 (参数), i)
如果真 (参数 [i] ≠ 0)
VirtualFreeEx (进程句柄, 参数 [i], 0, #MEM_RELEASE )

计次循环尾 ()
清除数组 (参数)
CloseHandle (进程句柄)
返回 ()

WaitForSingleObject (线程句柄, #DMUS_SEG_REPEAT_INFINITE )
' 获取调用函数执行后的返回值
GetExitCodeThread (线程句柄, 返回值)
' 批量释放申请的内存,关闭线程句柄及进程句柄
计次循环首 (取数组成员数 (参数), i)
如果真 (参数 [i] ≠ 0)
VirtualFreeEx (进程句柄, 参数 [i], 0, #MEM_RELEASE )

计次循环尾 ()
清除数组 (参数)
CloseHandle (线程句柄)
CloseHandle (进程句柄)
返回 ()


i支持库列表   支持库注释   
spec特殊功能支持库



补充内容 (2025-3-20 14:24):
不好意思,我刚刚解决了,论坛上找到一篇大佬设置的命令,已经解决了!
帖子链接:
https://bbs.125.la/forum.php?mod=viewthread&tid=1476...


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

本版积分规则 致发广告者

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

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

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