是否可以创建一个带有电子的tcp客户端? 或者我们可以访问铬套接字API吗?是否可以创建一个带电子的tcp客户端
https://developer.chrome.com/apps/sockets_tcp
是否可以创建一个带有电子的tcp客户端? 或者我们可以访问铬套接字API吗?是否可以创建一个带电子的tcp客户端
https://developer.chrome.com/apps/sockets_tcp
可以使用Node net
API在电子实现TCP客户端。
呦可以使用socket.io-client。示例代码:
//To connect to server
var socket = io.connect("http://Ip of server to which you want to connect" + "port Number");
//And to listen for events see below code
socket.on('event name', function (response) {
console.log("got from server", response)
});
仅测试Chrome API是否存在很容易。如果没有,我使用节点API。这样我的Chrome应用程序和我的电子应用程序具有相同的代码库。 这两个API略有不同,所以我在这里发布如何做到这一点。
let client = null; // node socket
let socketId; // chrome API socket id
function toBuffer(ab) {
return new Buffer(new Uint8Array(ab));
}
function toArrayBuffer(buf) {
return new Uint8Array(buf).buffer;
}
function initConnToServer (ip, port) {
return new Promise((resolve, reject) => {
if(typeof chrome !== 'undefined') {
chrome.sockets.tcp.create({}, r => {
socketId = r.socketId;
chrome.sockets.tcp.connect(r.socketId, ip, port, code => resolve(code));
});
} else {
client = new net.Socket(); // return a Node socket
client.connect(port, ip);
client.on('connect',() => resolve());
}
});
};
function sendToServer_simple (data) {
return new Promise((resolve, reject) => {
if(typeof chrome !== 'undefined') {
chrome.sockets.tcp.send(socketId, data, r => {});
chrome.sockets.tcp.onReceive.addListener(receiveInfo => resolve(receiveInfo.data));
} else {
client.write(toBuffer(data));
client.on('data', data => resolve(toArrayBuffer(data)));
}
});
};
您可以使用Electron中的Node net
API来实现TCP客户端。
尝试此示例代码(不要忘记更改IP地址)与一个小的套接字服务器为例如SocketTest Java应用程序(HERE)。
在连接处,您应该看到一个“世界!”服务器端的字符串。尝试从服务器发送此信息:
{
"nom":"Xplorer",
"prenom":"Yann"
}
你应该看到你好Yann!在你的电子控制台。
'use strict';
const electron = require('electron');
const app = electron.app;
const path = require('path');
const url = require('url');
const net = require('net');
const BrowserWindow = electron.BrowserWindow;
let mainWindow;
var socketClient
const BrowserWindow = electron.BrowserWindow;
let mainWindow;
var socketClient
function createWindow() {
// Create the browser window.
mainWindow = new BrowserWindow({width: 800, height: 600,backgroundColor:'#FFFFFF', frame:false})
// and load the index.html of the app.
mainWindow.loadURL(url.format({
pathname: path.join(__dirname+'/html/', 'main.html'),
protocol: 'file:',
slashes: true
}))
// Open the DevTools.
//mainWindow.webContents.openDevTools()
// Emitted when the window is closed.
mainWindow.on('closed', function() {
// Dereference the window object, usually you would store windows
// in an array if your app supports multi windows, this is the time
// when you should delete the corresponding element.
mainWindow = null
})
/* Instance socket on create window */
console.log('Try to connect');
socketClient = net.connect({host:'192.16.122.3', port:9042}, () => {
// 'connect' listener
console.log('connected to server!');
socketClient.write('world!\r\n');
});
socketClient.on('data', (data) => {
console.log(data.toString());
var person = JSON.parse(data);
console.log('Hello '+person.prenom+"!");
});
socketClient.on('end',() => {
console.log('disconnected from server');
});
//mainWindow.openDevTools();
}
app.on('before-quit',function(){
socketClient.end();
})
会见你。
谢谢,但我需要一个低TCP级别的API。 – Teebo