关于node.js和C交互的方法
下面來(lái)至https://blog.csdn.net/cut001/article/details/69397022的方法
FUNCTION ulong DesEnCodeHex(string str, string key, ref string outstr) library “zm_2007.dll”
int DesEnCodeHex(const char* str,const char* key, char* outstr) ; //c 接口描述 字符指針傳出
function long LIV_open(long vender,long index,ref long handle) library “l(fā)iving1.dll”
int LIV_open(int vender,int index, int* handle);c 接口描述 整形指針傳出。
function long LIV_get_hardware_info(long handle, ref LIV_hardware_info info) library “l(fā)iving1.dll”
int LIV_get_hardware_info(int handle,LIV_hardware_info info); //結(jié)構(gòu)體指針傳出
node.js調(diào)用動(dòng)態(tài)庫(kù),采用node-ffi 模塊。
var FFI = require(‘ffi’);
var ref = require(‘ref’);
var Struct = require(‘ref-struct’);
var refArray = require(‘ref-array’);
1、根據(jù)參數(shù)類型聲明函數(shù)。
char* => string //也可以直接用 char *
int* => ref.refType(‘int’) //也可以直接用 int *
struct *=>ref.refType(liv_hardware_info)
struct[] *=> ref.refType(liv_hardware_info,3) //結(jié)構(gòu)體數(shù)組
VOID * => ref.refType(‘pointer’)
結(jié)構(gòu)體中的參數(shù):
char* [] => refArray(‘byte’, 8)
基本類型
基本類型已經(jīng)定義在了ref.types里,可以直接使用類型字符串或者’ref.types’中的類型對(duì)象。而對(duì)于枚舉類型,簡(jiǎn)單當(dāng)作int或者uint處理就可以了。
指針
對(duì)于指針類型,簡(jiǎn)單類型可以直接在參數(shù)列表里寫int *,pointer這樣的,生成類型的指針可以用ref.refType(type)。在調(diào)用函數(shù)時(shí),執(zhí)行var vRef = ref.alloc(type)得到一個(gè)引用對(duì)象,將對(duì)象傳入函數(shù)即可。需要獲取vRef指向的值v可以用var v = ref.deref(vRef)。對(duì)字符串類型的buffer可能需要使用ref.readCString(buffer)來(lái)讀取(它可以處理末尾的’\0’)。
var intPtr = ref.refType(‘int’);
var liv_hardware_info = Struct({
‘developernumber’: ‘int’,
‘serialnumber’: refArray(‘byte’, 8),
‘manufacturedate’: ‘int’
});
let zm2007 = new FFI.Library(“./dll/zm_2007.dll”, {
‘DesEnCodeHex’: [‘int’, [‘string’, ‘string’, ‘string’]],
‘DesDeCodeHex’: [‘int’, [‘string’, ‘string’, ‘string’]],
‘LIV_open’: [‘int’, [‘int’, ‘int’, intPtr]],
‘LIV_get_hardware_info’: [‘int’, [‘int’, ref.refType(liv_hardware_info)]]
});
2、調(diào)用方法
var handleRef = ref.alloc(‘int’);//預(yù)先分配int 指針空間
let li_rtn = zm2007.LIV_open(0, 0, handleRef)
ll_handle = handleRef.deref();//獲取int值
var liv_info = new liv_hardware_info();//結(jié)構(gòu)體初始化
zm2007.LIV_get_hardware_info(ll_handle, liv_info.ref());//調(diào)用
const buf = Buffer.from(liv_info.serialnumber); //獲取已生成結(jié)構(gòu)體中屬性數(shù)據(jù)。
補(bǔ)充一點(diǎn):字符集引起的中文亂碼問(wèn)題
默認(rèn)node.js是utf8字符串,而我們的dll很多都是gbk編碼,從參數(shù)的傳入需要轉(zhuǎn)成gbk
轉(zhuǎn)碼一般用這個(gè)模塊,純js版本
var iconv = require(‘iconv-lite’);
var infoRef = new Buffer(512);//調(diào)用函數(shù)預(yù)先分配空間
//開(kāi)始調(diào)用。infoRef中是dll返回的gbk 數(shù)據(jù)串。
var as_data = iconv.decode(infoRef, ‘GBK’);//解碼成utf8.
var userbuffer = iconv.encode(as_data, ‘gbk’);//utf8數(shù)據(jù)編碼成gbk
總結(jié): 中文 傳入?yún)?shù)需要轉(zhuǎn)碼成gbk ,傳出參數(shù)需要轉(zhuǎn)碼成utf8.
先記錄,后面再加入內(nèi)存直接映射的方法。
與50位技術(shù)專家面對(duì)面20年技術(shù)見(jiàn)證,附贈(zèng)技術(shù)全景圖總結(jié)
以上是生活随笔為你收集整理的关于node.js和C交互的方法的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 【树莓派】为Ubuntu for ARM
- 下一篇: 关于有源晶振倍频干扰的问题