我有一个 google chrome web 扩展需要与 Qt 桌面应用程序通信 - 但如何?
有 chrome 的本地消息传递,但由于我想支持多种浏览器/操作系统,这将花费太多精力,因为它仅适用于 chrome。
然后是this建议设置本地服务器的帖子。这就是我所做的,见下文。
我已经在 127.0.0.1(本地主机)上使用 QTcpSocket
使用 QTcpServer
设置了一个带有 Qt 的服务器。但是网络扩展无法监听套接字,只能监听 chrome 应用程序 can .我想到了 2 种可能的解决方案:
作为解决方法,我或许可以编写一个小型 Chrome 应用程序。 Qt 应用程序将通过 chrome 应用程序与 chrome 扩展对话(chrome 应用程序支持套接字)。但我认为这种方法很笨拙而且不太优雅。
另一方面,我阅读了关于
socket.io
的内容。 这个想法是:chrome 扩展通过http 请求
与 socket.io 对话,而 socket.io 通过套接字与我的桌面应用程序对话。这是一个可能的解决方案吗?
我也试过,是用下面的代码直接连接到本地服务器。在我的 Qt 服务器应用程序中,我看到有一个新连接。但是我根本得不到响应(要么是我的Qt代码错误,要么是因为扩展不能监听套接字?)
var xhr = new XMLHttpRequest();
xhr.open("GET", "http://localhost:12345", true);
xhr.onreadystatechange = function() {
if (xhr.readyState == 4) {
alert('This is the response from the server: '+ xhr.responseText );
}
最佳答案
如您所知,扩展不能创建直接连接:
Google Chrome Socket API in extensions
可能的解决方案
也许您的 QT 应用程序可以为 websocket 提供服务,并且您应该能够通过 Javascript 与它进行通信:
http://www.html5rocks.com/en/tutorials/websockets/basics/
如果您无法从 QT 应用程序内部提供 websockets,另一种方法是创建一个“桥接器”,一个小脚本,可以为您的 JavaScript 提供 websockets 并从/向 QT 应用程序传递消息
你会在 websockets 上找到很多例子,进入这个的简单方法可能是使用 node.js 创建一个小服务器来玩它 stackabuse.com/node-js-websocket-examples-with-socket-io/
哦!并搜索“websocket 同源策略”
使用 websockets 的扩展示例(这对调试很有用):chrome.google.com/webstore/detail/simple-websocket-client/pfdhoblngboilpfeibdedpjgfnlcodoo?hl=en
希望对你有帮助
关于sockets - 如何将 chrome web 扩展与本地主机服务器连接?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34970213/