Nodejs 调用 dll

1. 环境

  • Visual Studio 15
  • Nodejs 18.16.1

2. 动态链接库dll生成

2.1 新建项目

2.2 项目结构和代码

2.2.1 项目结构

2.2.2 代码示例

  • pch.h文件
arduino 复制代码
#ifndef PCH_H
#define PCH_H

// 添加要在此处预编译的标头
#include "framework.h"

#endif //PCH_H

//定义宏
#ifdef  IMPORT_DLL
#else
#define IMPORT_DLL extern "C" _declspec(dllimport)
#endif //  IMPORT_DLL

IMPORT_DLL int add(int a, int b);
  • dllmain.cpp 文件
arduino 复制代码
// dllmain.cpp : 定义 DLL 应用程序的入口点。
#include "pch.h"

int add(int a, int b) {
	return a + b;
}

2.3生成dll文件

右键点击"生成",生成dll文件

3. 使用ffi-napi 或 koffi调用dll

本例使用为ffi-napi,但是在electron 等项目中,可能会出现build之后无法使用dll的情况,可以换成koffi

sql 复制代码
安装ffi-napi
yarn add ffi-napi

如果需要复杂数据类型,可以使用ref-napi 、ref-array-napi等
yarn add  ref-napi 
  • app.js
ini 复制代码
const ffi = require('ffi-napi');
const ref = require('ref-napi');
const ArrayType = require('ref-array-napi');

// 定义数组类型
const IntArray = ArrayType(ref.types.int);
const doubleArray = ArrayType(ref.types.double);

// 创建数组实例
const array = new IntArray([15, 25]);


let libm = ffi.Library("D:\\code\\cjj-workspace\\Dll4\\x64\\Release\\Dll4.dll", {
    'add': ['int', ['int', 'int']],
})

let tmp = libm.add(4, 9)
console.log(tmp)

执行结果:

4. 一些踩坑

  1. 调用dll报错 Dynamic Symbol Retrieval Error: Win32 error 127或者 Dynamic Linking Error: Win32 error 126

通常是因为找不到dll抛出的方法。 在Node.js中调用使用C++编译的DLL文件时,通常需要使用extern "C"来确保正确的函数签名和名称。 因为编译器在将源代码编译为二进制代码时会对函数名称进行"名称修饰"(Name Mangling),也称为名称混淆。这是为了在编译期间解决函数重载和类型安全的问题。名称修饰会改变函数名称的格式。

  1. dll发到缺少visual studio的环境,报错Dynamic Linking Error: Win32 error 126
  1. 检查dll路径是否错误
  2. 检查dll是否发的是release版本 通常vs生成的dll,默认是debug模式,这个模式生成的dll放到其他人的电脑不能直接使用的。想要生成移植到其他电脑也能使用的dll,需要点击 项目->属性 进行配置
相关推荐
天下代码客6 小时前
使用electronc框架调用dll动态链接库流程和避坑
前端·javascript·vue.js·electron·node.js
weixin199701080166 小时前
【性能提升300%】仿1688首页的Webpack优化全记录
前端·webpack·node.js
不倒翁玩偶8 小时前
npm : 无法将“npm”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保路径正确,然后再试一次。
前端·npm·node.js
一心赚狗粮的宇叔10 小时前
03.Node.js依赖包补充说明及React&Node.Js项目
前端·react.js·node.js
-嘟囔着拯救世界-10 小时前
【2026 最新版】OpenAI 祭出王炸 GPT-5.3-Codex!Win11 + VSCode 部署保姆级教程
vscode·gpt·chatgpt·node.js·node·codex·gpt5
全栈前端老曹1 天前
【MongoDB】Node.js 集成 —— Mongoose ORM、Schema 设计、Model 操作
前端·javascript·数据库·mongodb·node.js·nosql·全栈
行者无疆_ty1 天前
什么是Node.js,跟OpenCode/OpenClaw有什么关系?
人工智能·node.js·openclaw
-凌凌漆-1 天前
【npm】npm的-D选项介绍
前端·npm·node.js
lucky67071 天前
Windows 上彻底卸载 Node.js
windows·node.js
Android系统攻城狮1 天前
鸿蒙系统Openharmony5.1.0系统之解决编译时:Node.js版本不匹配问题(二)
node.js·鸿蒙系统·openharmony·编译问题·5.1