开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 1197|回复: 21
收起左侧

[求助] dll调用问题

[复制链接]
结帖率:100% (2/2)
发表于 2023-11-6 21:43:55 | 显示全部楼层 |阅读模式   广东省广州市
#include <windows.h>
#include <string>

import libpe;
using namespace libpe;

// 函数声明,用于将字符串写入buffer,并更新偏移量
void WriteStringToBuffer(const std::string& str, char*& buffer, size_t& offset) {
    size_t length = str.length() + 1;  // 加1是为了空字符
    memcpy(buffer + offset, str.c_str(), length);
    offset += length;
}

// 声明导出函数
extern "C" __declspec(dllexport) void AnalyzePE(const wchar_t* filepath, void* outputBuffer);

// 导出函数的实现
void AnalyzePE(const wchar_t* filepath, void* outputBuffer) {
    Clibpe pe(filepath);
    const auto peImp = pe.GetImport();
    if (!peImp) {
        return;
    }

    char* buffer = static_cast<char*>(outputBuffer);
    size_t offset = 0;
    // 遍历所有导入的模块和函数
    for (const auto& itModule : *peImp) {
        for (const auto& itFunc : itModule.vecImportFunc) {
            // 将每个函数名写入buffer
            WriteStringToBuffer(itFunc.strFuncName, buffer, offset);
        }
    }

    // 确保在数组的最后放置一个额外的空字符作为结束标志
    buffer[offset] = '\0';
}

以上是dll的代码,以下是易语言得到代码,文件地址能正常传递到dll,但是dll运行到导入表的部分就会崩崩溃
.版本 2

.子程序 _临时子程序
.局部变量 导入表, 字节集, , "0"

' 本名称子程序用作测试程序用,仅在开发及调试环境中有效,编译发布程序前将被系统自动清空,请将所有用作测试的临时代码放在本子程序中。 ***注意不要修改本子程序的名称、参数及返回值类型。
获取导入表 (编码_Ansi到Unicode (“C:\Users\Kolomina\OneDrive - MSFT\KolominaAntiVirus_New\KoloAntiScript.dll”, 假), 导入表)
返回 ()

.子程序 获取导入表, 逻辑型, 公开
.参数 文件路径, 字节集
.参数 返回的导入表, 字节集, 数组

AnalyzePE (文件路径, 返回的导入表)
返回 (真)

结帖率:100% (2/2)
 楼主| 发表于 2023-11-7 21:24:18 | 显示全部楼层   广东省广州市
解决了,改了dll,变成函数回调就行了
回复 支持 反对

使用道具 举报

结帖率:90% (9/10)

签到天数: 6 天

发表于 2023-11-6 21:49:59 | 显示全部楼层   重庆市重庆市
第二个参数不是字节集数组
回复 支持 反对

使用道具 举报

签到天数: 5 天

发表于 2023-11-6 21:56:10 | 显示全部楼层   重庆市重庆市
既然是 outputBuffer 保存结果 肯定要申请内存存放啊
回复 支持 反对

使用道具 举报

结帖率:100% (18/18)

签到天数: 6 天

发表于 2023-11-6 23:10:34 | 显示全部楼层   广东省惠州市
你要先了解outputBuffer数据是一个怎样的结构,还要了解字节集数组又是怎样的结构.结构都不一样.你直接字节集数组接收是行不通的.先用一个整数型接收这个堆栈指针.要算偏移取出相关值.最后,你还得一一手工代码释放DLL所产生的堆栈数据!!
回复 支持 反对

使用道具 举报

结帖率:100% (18/18)

签到天数: 6 天

发表于 2023-11-6 23:17:07 | 显示全部楼层   广东省惠州市
我记得char*好像是易语言文本型都支持的字节数组.你用文本型数组看下能接收不,不能就用整数型接收指针,算偏移量转化了.最后,你还要手工释放堆栈!
回复 支持 反对

使用道具 举报

结帖率:60% (3/5)

签到天数: 6 天

发表于 2023-11-7 01:29:54 | 显示全部楼层   广西壮族自治区柳州市
DLL谁调用谁分配内存存放返回数据,这是常识吧,
字节集数组仅仅是一个空指针,没有实际分配的内存,这不崩天理不容
回复 支持 反对

使用道具 举报

结帖率:100% (2/2)
 楼主| 发表于 2023-11-7 06:55:54 | 显示全部楼层   广东省广州市
呵呵仙 发表于 2023-11-6 23:10
你要先了解outputBuffer数据是一个怎样的结构,还要了解字节集数组又是怎样的结构.结构都不一样.你直接字节 ...

请问要怎么写呢?求帮助
回复 支持 反对

使用道具 举报

结帖率:100% (2/2)
 楼主| 发表于 2023-11-7 16:45:28 | 显示全部楼层   广东省广州市
呵呵仙 发表于 2023-11-6 23:17
我记得char*好像是易语言文本型都支持的字节数组.你用文本型数组看下能接收不,不能就用整数型接收指针,算偏 ...

改为文本型数组之后显示dll堆栈错误
回复 支持 反对

使用道具 举报

结帖率:100% (2/2)
 楼主| 发表于 2023-11-7 16:47:36 | 显示全部楼层   广东省广州市
dnxl 发表于 2023-11-7 01:29
DLL谁调用谁分配内存存放返回数据,这是常识吧,
字节集数组仅仅是一个空指针,没有实际分配的内存,这不崩 ...

导入表 = 取空白字节集 (100000000000)
这样子写了之后应该算申请了内存了吧?依然崩溃
回复 支持 反对

使用道具 举报

结帖率:100% (2/2)
 楼主| 发表于 2023-11-7 16:48:19 | 显示全部楼层   广东省广州市
神女软件定制 发表于 2023-11-6 21:49
第二个参数不是字节集数组

导入表 = 取空白字节集 (100000000000)
这样子写了之后应该算申请了内存了吧?依然崩溃

补充内容 (2023-11-7 16:48):
回复错人了
回复 支持 反对

使用道具 举报

  高级模式
B Color Image Link Quote Code Smilies |上传

本版积分规则 致发广告者

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

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

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