我正在使用term.js
通过 Javascript &在网络浏览器中模拟终端Node.js
。
我已经设置了基本实现&可以连接到本地和远程主机(我使用节点 ssh2 连接到远程主机)&一切正常如预期的那样。
但是一切都是黑色和白色(黑色背景,白色文本)。
我在客户端中有以下代码,这是根据存储库中的示例。我应该添加一些额外的配置来启用颜色吗?
var term = new Terminal({
colors: Terminal.colors, //This alone doesnt seem to work
cols: 80,
rows: 24,
useStyle: true,
screenKeys: true,
cursorBlink: true
});
答案 0 :(得分:5)
颜色适合我。这是我在Ubuntu上的测试设置:
首先安装依赖项:npm install express socket.io ssh2 term.js
在远程服务器上安装colortest
软件包(您已经加入)sudo apt-get install colortest -y
<强> server.js:强>
var express = require('express');
var app = express();
var server = require('http').Server(app);
var io = require('socket.io')(server);
var term = require('term.js');
var ssh = require('ssh2');
server.listen(8000);
app.use(express.static(__dirname + '/public'));
app.use(term.middleware());
io.on('connection', function (socket) {
var conn = new ssh();
conn.on('ready', function() {
socket.emit('data', '\n*** SSH CONNECTION ESTABLISHED ***\n');
conn.exec('env TERM=xterm-256color colortest-256', function(err, stream) {
if (err)
return socket.emit('data', '\n*** SSH EXEC ERROR: ' + err.message + ' ***\n');
stream.on('data', function(d) {
socket.emit('data', d.toString('binary'));
}).on('close', function() {
conn.end();
});
});
}).on('close', function() {
socket.emit('data', '\n*** SSH CONNECTION CLOSED ***\n');
}).connect({
host: '192.168.100.105',
port: 22,
username: 'foo',
password: 'barbaz',
});
});
公开/ client.htm:强>
<html>
<head>
<title>WebTerm</title>
<script src="/socket.io/socket.io.js"></script>
<script src="/term.js"></script>
<script>
window.addEventListener('load', function() {
var socket = io.connect();
socket.on('connect', function() {
var term = new Terminal({
cols: 250,
rows: 100,
convertEol: true,
useStyle: true,
cursorBlink: true,
screenKeys: true
});
term.on('data', function(data) {
socket.emit('data', data);
});
term.on('title', function(title) {
document.title = title;
});
term.open(document.body);
socket.on('data', function(data) {
term.write(data);
});
socket.on('disconnect', function() {
term.destroy();
});
});
}, false);
</script>
</head>
<body>
</body>
</html>
执行node server.js
,然后在浏览器中访问http://localhost:8000/client.htm
。您应该看到类似this的内容。