Cordova chrome.socket API。有什么例子吗?

标签 cordova google-chrome-app

我正在尝试使用 org.chromium.socket 插件。但我找不到很多例子。这是我的代码:

var connButton = document.getElementById("connButton");

connButton.addEventListener("click", doConnect, false);

function doConnect() {
    var theSocketId = 0;
    chrome.socket.create("tcp", null, function(createInfo) {
        alert(createInfo.socketId);
        theSocketId = createInfo.socketId;
     });
     chrome.socket.connect(theSocketId, "http://www.yahoo.com", 80, function(result) {
        alert(result);
     });
chrome.socket.read(theSocketId, 1000, function(readInfo) {
      alert(readInfo.resultCode);
  });
  }

我尝试将主机名更改为不同的 IP 或更改端口。但有时我看到结果 = -1000,这表明失败。或者有时我看不到结果警报。我也有使用 chrome.socket.read 的问题。

请批评我的代码。非常感谢你!

最佳答案

该插件的最佳 API 示例可能是在 GitHub 上发布的 https://github.com/GoogleChrome/chrome-app-samples/ 示例。 .它们适用于插件实现的 chrome.socket API。特别是,您可以查看 TCP Server , Web ServerWebsocket Server .

早在 9 月,我还使用该插件作为演示编写了一个简单的 Web 服务器;你可以找到它on GitHub here

但是,这些示例都显示了服务器套接字——我没有一个很好的示例来向您展示客户端。

就您的代码而言,有两件事立即脱颖而出:

首先,您尝试连接到 TCP 端口 0,这几乎肯定是不正确的。要连接到 HTTP 服务,您应该在地址中省略“http://”——只使用服务器名称,并使用 80 作为端口号。

其次,您好像在调用 chrome.socket.connect紧接在 chrome.socket.create 之后, 和 chrome.socket.read紧接在 chrome.socket.connect 之后,而不是在回调中执行这些操作。这可能意味着连接调用可以在创建完成之前发出,或者读取调用可以在绑定(bind)调用完成之前发出。我将从嵌套调用开始,如下所示:

chrome.socket.create("tcp", null, function(createInfo) {
    alert(createInfo.socketId);
    theSocketId = createInfo.socketId;
    chrome.socket.connect(theSocketId, "www.yahoo.com", 80, function(result) {
        alert(result);
        if (result === 0) {
            chrome.socket.read(theSocketId, 1000, function(readInfo) {
                alert(readInfo.resultCode);
            });
        }
    });
});

然而,接下来要阻止它工作的是代码实际上并没有向服务器发送任何请求。 chrome.socket是一个低级接口(interface),因此如果您想通过 HTTP 进行通信,您的应用程序将不得不使用 HTTP。

一段非常简单的示例代码将与 Web 服务器通信,并返回其主页的前一千字节,如下所示:
// Utility functions to convert between array buffers and strings

function stringToArrayBuffer(string) {
    var buffer = new ArrayBuffer(string.length);
    var bufView = new Uint8Array(buffer);
    for (var i=0; i < string.length; i++) {
        bufView[i] = string.charCodeAt(i);
    }
    return buffer;
}

function arrayBufferToString(buffer) {
    return String.fromCharCode.apply(null, new Uint8Array(buffer));
}

// Set the hostname; we'll need it for the HTTP request as well
var hostname = "www.yahoo.com";

chrome.socket.create("tcp", function(createInfo) {
    var socketId = createInfo.socketId;
    chrome.socket.connect(socketId, hostname, 80, function(result) {
        if (result === 0) {
            var requestString = "GET / HTTP/1.1\r\nHost: "+hostname+"\r\nConnection: close\r\n\r\n";
            var requestBuffer = stringToArrayBuffer(requestString);
            chrome.socket.write(socketId, requestBuffer, function(writeInfo) {
                chrome.socket.read(socketId, 1000, function(readInfo) {
                    var htmlString = arrayBufferToString(readInfo.data);
                    // do something with htmlString here
                });
            });
        }
    });
});

关于Cordova chrome.socket API。有什么例子吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22549111/

相关文章:

javascript - 如何在android中从服务器发送命令功能而不发送请求?

javascript - Phonegap - 页面显示但不加载 javascript

cordova - 减小 Cordova apk 的大小

javascript - 如何在 Android 上自动打开 GPS?

javascript - 如何允许在 Google Chrome 应用程序中的 webview 内下载?

ios - Cordova 应用程序在 safari 上运行良好,但作为应用程序安装时崩溃

javascript - Chrome 未设置本地存储

google-chrome-extension - 适用于 Chrome 应用程序的 Google Analytics(分析)

javascript - Chrome 扩展 - Chrome.storage - 为什么 chrome.storage.sync.get 返回未定义?

javascript - 是否有任何显示公告消息让用户知道新版本更新?