2022.3.23日报:_open_osfhandle、_get_osfhandle不能跨模块调用(调试ASAR功能里发现的)

1,今天在修改一个mini-electron的bug,就是mini-electron加载asar有时候提示文件UV_EBADF。

原因是asar的Archive::Archive函数,会调用_open_osfhandle获取fd,然后传到nodejs的

static void Read(const FunctionCallbackInfo<Value>& args)

里,再用_get_osfhandle获取fd对应的windows句柄。

然而这里有个问题,就是_open_osfhandle这些是crt的函数,如果我们编译的时候选择MT模式,也就是把crt编译到dll、exe里,就会有问题。因为_open_osfhandle内部是缓存了一个数组。这个数组在不同模块里肯定不是同一个。所以就导致了今天这个问题。在不同模块,调用_open_osfhandle、_get_osfhandle是不会成功的。

说到这里要讲解下electron的asar机制。

在apiasar.cpp里(原版electron应该也是类似的),initAsarSupport这个会注入一个asar_init.js文件,hook nodejs的fs模块。

当fs模块调用read 之类的函数,会走入asar_init.js里的hook函数。在这里面,会检测读写的路径是不是asar模块里的。如果是的话就走c++层读取真正的文件。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值