- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我不明白,我该如何配置 LEX使用 socket.io。这是我现在拥有的:
服务器.js
var express = require('express');
var app = express();
var bodyParser = require('body-parser');
app.use(bodyParser.urlencoded({limit: '50mb', extended: true }));
app.use(bodyParser.json({limit: '50mb'}));
var port = 80;
if(process.argv[2] == 'dev') port = 3001;
var router = express.Router();
app.use(function (req, res, next) {
res.setHeader('Access-Control-Allow-Origin', '*');
res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS, PUT, PATCH, DELETE');
res.setHeader('Access-Control-Allow-Headers', 'X-Requested-With,content-type, userId');
next();
});
var api = require('./api');
api(app, port)
app.use(express.static(__dirname + "/../dist"));
app.get('/', function(req, res) {
res.render('index.html');
});
console.log('Magic happens on port ' + port);
API.js
var API = function(app, port){
var pg = require('pg');
var lex = require('letsencrypt-express').testing();
var connectedUsers = {};
var config ={
user: "postgres",
password: "password",
database: "production",
port: 5432,
host: "serverIpAddress",
ssl: false
};
pg.connect(config, function(err, client, done) {
if (err) {
return console.error('error fetching client from pool', err);
}
// var server = require('http').Server(app);
var server = lex.create({
configDir: './letsencrypt.config',
onRequest: app,
letsencrypt: null,
});
var io = require('socket.io')(server);
server.listen(port);
io.on('connection', function (socket) {
console.log('new connection')
});
});
}
module.exports = API
看看 api.js 中的注释行:当我使用它而不是时一切正常:
var server = lex.create({
configDir: './letsencrypt.config',
onRequest: app,
letsencrypt: null,
});
使用 LEX,我在尝试运行服务器时收到此错误:
[LEX] testing mode turned on
[LEX] default server: https://acme-staging.api.letsencrypt.org/directory
###################################################
# #
# Open up a browser and visit this server #
# at its domain name. #
# #
# ENJOY! #
# #
###################################################
Note: testing certs will be installed because .testing() was called.
remove .testing() to get live certs.
[LEX] automatic registration handling turned on for testing.
Magic happens on port 3001
[LEX] creating sniCallback {
"configDir": "./letsencrypt.config",
"onRequest": {
"domain": null,
"_events": {},
"_eventsCount": 3,
"_connections": 0,
"_handle": null,
"_usingSlaves": false,
"_slaves": [],
"_unref": false,
"allowHalfOpen": true,
"pauseOnConnect": false,
"httpAllowHalfOpen": false,
"timeout": 120000
},
"letsencrypt": {
"backend": {}
},
"debug": true,
"webrootPath": "/var/folders/2m/vfw1bgqd4pv7hk86kcbvcrlc0000gn/T/acme-challenge",
"privkeyPath": "./letsencrypt.config/live/:hostname/privkey.pem",
"fullchainPath": "./letsencrypt.config/live/:hostname/fullchain.pem",
"certPath": "./letsencrypt.config/live/:hostname/cert.pem",
"chainPath": "./letsencrypt.config/live/:hostname/chain.pem",
"server": "https://acme-staging.api.letsencrypt.org/directory"
}
projectRootFolder/node_modules/socket.io/node_modules/engine.io/lib/server.js:358
var listeners = server.listeners('request').slice(0);
^
TypeError: server.listeners is not a function
at Server.attach (projectRootFolder/node_modules/socket.io/node_modules/engine.io/lib/server.js:358:26)
at Function.attach (projectRootFolder/node_modules/socket.io/node_modules/engine.io/lib/engine.io.js:124:10)
at Server.listen.Server.attach (projectRootFolder/node_modules/socket.io/lib/index.js:226:21)
at new Server (projectRootFolder/node_modules/socket.io/lib/index.js:51:17)
at Server (projectRootFolder/node_modules/socket.io/lib/index.js:39:41)
at projectRootFolder/server/api.js:73:34
at projectRootFolder/node_modules/pg/lib/pool.js:82:9
at projectRootFolder/node_modules/pg/node_modules/generic-pool/lib/generic-pool.js:281:11
at projectRootFolder/node_modules/pg/lib/pool.js:56:18
at null.<anonymous> (projectRootFolder/node_modules/pg/lib/client.js:149:7)
at g (events.js:260:16)
at emitOne (events.js:82:20)
at emit (events.js:169:7)
at Socket.<anonymous> (projectRootFolder/node_modules/pg/lib/connection.js:109:12)
at emitOne (events.js:77:13)
at Socket.emit (events.js:169:7)
我想,我的代码中有一个非常简单的错误,因为我之前没有使用 SSL 配置 Socket.io。
谢谢
最佳答案
试试这段代码。它只适用于最新版本的 letsencrypt-express。
应用程序.js
var express = require('express');
var app = express();
var socketIO = require('socket.io');
var LEX = require('letsencrypt-express').testing();
var https = require('http2');
app.get('/', function (req, res) {
res.sendFile(__dirname + '/index.html');
});
var lex = LEX.create({
configDir: '/etc/letsencrypt'
, letsencrypt: null
, approveRegistration: function (hostname, cb) {
cb(null, {
domains: ['example.com']
, email: 'info@example.com'
, agreeTos: true
});
}
});
var server = https.createServer(lex.httpsOptions, LEX.createAcmeResponder(lex, app));
server.listen(443);
var io = socketIO.listen(server);
io.on('connection', function (socket) {
socket.emit('news', { hello: 'world' });
socket.on('my other event', function (data) {
console.log(data);
});
});
index.html
<script src="https://cdn.socket.io/socket.io-1.4.5.js"></script>
<script>
var socket = io.connect('https://example.com');
socket.on('news', function (data) {
console.log(data);
socket.emit('my other event', { my: 'data' });
});
</script>
关于node.js - 使用 Socket.IO 的 letsencrypt-express,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35332191/
我有一个以以下方式运行的简单docker容器: docker service create --name nginx_proxy \ --mount type=bind,source=/opt/n
所以我有一个在端口 443 上运行的 Apache 服务器和在最新版本的 Ubuntu 上安装的 NodeJS。现在我的一切都运行得很好,除了我运行 NodeJS 服务器的端口 100 上没有 SSL
所以我删除了证书,认为我需要这样做,因为我得到了一个新域名。我目前被当前错误困住了: Root@Site:~$ certbot-auto --apache -d example.io -d www.e
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我关注了this tutorial使用 NGINX Ingrss Controller 和带有 letsencrypt 的证书管理器为基本应用程序提供服务。 我可以访问该网站,但 SSL 证书已损坏,
我正在将我的网站推送到 Ubuntu 18.04 上的 AWS Lightsail 实例,但自从我安装了 LetsEncrypt(之前一切都很好)后,我无法访问它。 基本上,我没有得到任何回应,尽管看
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我正在尝试找出如何在不影响用户/客户的情况下将网站/服务器从 digitalocean Droplet 迁移到 Azure (AKS)。 digitalocean 配置具有由letsencrypt(通
我正在尝试找出如何在不影响用户/客户的情况下将网站/服务器从 digitalocean Droplet 迁移到 Azure (AKS)。 digitalocean 配置具有由letsencrypt(通
我正在遵循本指南:https://www.digitalocean.com/community/tutorials/how-to-set-up-let-s-encrypt-certificates-f
我在尝试运行命令时遇到这个奇怪的 letsencrypt 错误 $ certbot certonly --standalone --email example@gmail.com --agree-to
Closed. This question needs details or clarity。它当前不接受答案。
我正在尝试在 DigitalOcean 服务器上的 ubuntu 14 上安装 letsencrypt,但遇到了这个问题。 我尝试使用 sudo 安装但同样的错误,也尝试安装库但没有任何反应。 apt
我已经在我的服务器上安装了 SSL 来保护我的域,现在发生的事情是我在 Chrome 等中遇到了这个错误: Attackers might be trying to steal your inform
我目前在我的服务器上使用 letsencrypt 作为 SSL 证书。随着我服务器上的站点数量不断增加,安装运行 ssh 命令的证书变得非常耗时:letsencrypt。我必须手动取消选中我不想安装
当时,我无法再解决问题了……说真的,我太蠢了,检查了 letsencrypt ssl 并同时创建了一个自签名证书。但是,我认为我已经破坏了 SSL 配置。使用 letsencrypt 的其他域,除了一
我已经在 WHM 上安装了 lets encrypt,但它不适用于域。我希望每当我添加域(附加域)时,它都会被分配让加密但它会 self 分配,这表明网站不安全并且无法在 HTTPS 上运行。 我 c
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwa
我正在尝试在需要时自动为新服务器提供午餐,但在使服务器上线之前我在获取证书时遇到了一些困难。我想要做的是运行一个安装脚本,它准备好所有的包、网站和证书,然后将服务器添加到生产环境中。但是,Letsen
我有一个 digitalocean 服务器(ubuntu 16.4 nginx)+ serverpilot我按照站点教程安装了 letsencrypt:https://www.robertwent.c
我是一名优秀的程序员,十分优秀!