如何修复我的 Mac 版 Chrome 浏览器扩展中的“本机主机已退出”错误?Native Messaging上的文档在底部特别提到了这个错误,并提出了一个可能的原因,但它的表述很笼统(“这很可能是从你的本地消息传递主机启动的”),并且不清楚要尝试做什么来解决这个。
终端中的日志输出(如果您从 Mac 终端启动 Chrome,则可以查看日志信息)使我相信本机主机应用程序的进程本身从未成功启动。我不断得到:
LaunchProcess: failed to execvp:
/Users/mycomputer1/Documents/myhost.app
但是,在后台 javascript 页面的控制台上打印“Native host has exited”的实际代码是:
function onDisconnected() {
console.log("Inside onDisconnected(): " + chrome.runtime.lastError.message);
port = null;
}
onDisconnected() 侦听器实际上是调用 connectNative() 的结果,我根据文档在此处完成了此操作:
chrome.runtime.onMessageExternal.addListener(
function(request, sender, sendResponse) {
//var imgdata = JSON.stringify(request.imgdata);
//process it somehow here
port = chrome.runtime.connectNative("com.allinlearning.ailhost");
if (port)
{
console.log("connectNative() returned a non-null port");
}
});
我知道 connectNative() 在某种程度上成功,因为它返回了一个有效的端口。但是,connectNative() 继续尝试定位本机主机应用程序并尝试启动它。文档表明主机应用程序是罪魁祸首,以某种方式启动了 Chrome 和本机应用程序之间的“管道”中断,尽管我的主机应用程序根本没有实现与 stdout 或 stdin 的通信。此外,Chrome 日志消息(“LaunchProcess: failed to execvp:”)似乎表明我的 Mac 应用程序甚至从未成功启动。
还有更多:我在网上找到的一些源代码(可能是过时的?源文件)揭示了这个“本机主机已退出”消息的确切来源,并且检查表明为什么 Google Chrome 的代码正在关闭。在 HandleReadResult() 中,调用 Close() 提供非常消息,然后关闭事物以响应 Posix read() 返回 0。但是在广泛的体育世界中,我做错了什么(或根本不做)在我的 Mac 应用程序中导致读取失败?我的 Mac 应用程序没有向标准输出写入任何内容,那么 not-writing-anything 是如何导致读取错误的?还是所有这些都在误导我,而 execvp 未能启动我的主机应用程序是更深层次的原因?如果是这样,为什么?这是一个简单的、准系统的 Mac 应用程序。