Cordova chrome.socket API.任何例子?

Cordova chrome.socket API.任何例子?,第1张

概述我正在尝试使用org.chromium.socket插件.但我找不到很多例子.这是我的代码: var connButton = document.getElementById("connButton");connButton.addEventListener("click", doConnect, false);function doConnect() { var theSocke 我正在尝试使用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示例可能是在 https://github.com/GoogleChrome/chrome-app-samples/年在GitHub上发布的.它们用于Chrome.socket API,这是插件实现的.特别是,您可以查看 TCP Server,Web Server和 Websocket Server.

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

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

就你的代码而言,有两件事情可以立即脱颖而出:

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

其次,看起来你在Chrome.socket.create之后立即调用Chrome.socket.connect,在Chrome.socket.connect之后立即调用Chrome.socket.read,而不是在回调中执行这些 *** 作.这可能意味着可以在创建完成之前发出connect调用,或者可以在完成绑定调用之前发出read调用.我会从嵌套调用开始,像这样:

Chrome.socket.create("tcp",function(createInfo) {    alert(createInfo.socketID);    theSocketID = createInfo.socketID;    Chrome.socket.connect(theSocketID,"www.yahoo.com",function(result) {        alert(result);        if (result === 0) {            Chrome.socket.read(theSocketID,function(readInfo) {                alert(readInfo.resultCode);            });        }    });});

但是,接下来要阻止它工作的是代码实际上并没有向服务器发送任何请求. Chrome.socket是一个低级接口,所以如果你想通过http进行通信,你的应用就必须要谈http.

一个非常简单的示例代码将与Web服务器通信,并返回其主页的前1000个字节,如下所示:

// Utility functions to convert between array buffers and stringsfunction 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 wellvar hostname = "www.yahoo.com";Chrome.socket.create("tcp",function(createInfo) {    var socketID = createInfo.socketID;    Chrome.socket.connect(socketID,hostname,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,function(readInfo) {                    var HTMLString = arrayBufferToString(readInfo.data);                    // do something with HTMLString here                });            });        }    });});
总结

以上是内存溢出为你收集整理的Cordova chrome.socket API.任何例子?全部内容,希望文章能够帮你解决Cordova chrome.socket API.任何例子?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1000740.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-21
下一篇 2022-05-21

发表评论

登录后才能评论

评论列表(0条)

保存