我有一个用featherjs制作的应用程序,我想用https运行。我已经做到了。我通过将"index.js"文件更改为如下所示来做到这一点:
const fs = require('fs');
const https = require('https');
const app = require('./app');
const port = app.get('port');
const host = app.get('host');
//const server = app.listen(port);
const server = https.createServer({
key: fs.readFileSync('./certs/aex007.key'),
cert: fs.readFileSync('./certs/aex007.crt')
}, app).listen(port, function(){
console.log("Mfp Backend started: https://" + host + ":" + port);
});
我现在一去邮递员中的"https://127.0.0.1/a_service_name",我就会在接受证书后得到结果。当我在浏览器中访问地址时,它也给出了结果,证书指示为"红色",因为它是自签名的。
所以我的问题如下。当我在浏览器中转到"http://127.0.01"时,除了"index.html"文件之外,我没有得到任何"套接字"信息,只有一个空白页。我在控制台中收到以下错误
信息: (404) 路线:/socket.io/?EIO=3&transport=polling&t=LwydYAw - 未找到页面
然后我正在使用的"index.html"文件当前包含以下内容:
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/socket.io/2.0.3/socket.io.js"></script>
<script type="text/javascript" src="//cdn.rawgit.com/feathersjs/feathers-client/v1.1.0/dist/feathers.js"></script>
<script type="text/javascript">
var socket = io('https://127.0.0.1:3001');
var client = feathers()
.configure(feathers.hooks())
.configure(feathers.socketio(socket));
var todoService = client.service('/some_service');
todoService.on('created', function(todo) {
alert('created');
console.log('Someone created a todo', todo);
});
</script>
有人可以向我解释如何获取警报消息吗?
编辑 2017/09/27 我在互联网上发现 socket.io 配置如下
var https = require('https'),
fs = require('fs');
var options = {
key: fs.readFileSync('ssl/server.key'),
cert: fs.readFileSync('ssl/server.crt'),
ca: fs.readFileSync('ssl/ca.crt')
};
var app = https.createServer(options);
io = require('socket.io').listen(app); //socket.io server listens to https connections
app.listen(8895, "0.0.0.0");
但是,feathers-socket.io 的要求在应用程序中.js而不是索引.js。我想知道我是否可以移动它?
正如 daffl 在羽毛松弛频道上指出的那样; 除了文档的 https 部分外,在应用程序上调用configure
之前,请查看明确要求feathers-socketio
的文档。将这两者放在一起,我会做这样的事情(未经测试):
const feathers = require('feathers');
const socketio = require('feathers-socketio');
const fs = require('fs');
const https = require('https');
const app = feathers();
app.configure(socketio());
const opts = {
key: fs.readFileSync('privatekey.pem'),
cert: fs.readFileSync('certificate.pem')
};
const server = https.createServer(opts, app).listen(443);
// magic sauce! Socket w/ ssl
app.setup(server);
您的app.js
和index.js
的结构完全取决于您。如图所示,您可以在单个文件中执行上述所有操作,或者将 https/fs 要求拆分为 index.js,并将应用程序配置为应用程序.js - 我推荐这种方法,因为如果您决定使用像 nginx 这样的反向代理来处理 ssl 而不是 node,它将允许您更改(通常较小的)index.js 文件。