feathersjs -> socketio https 请求不起作用



我有一个用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.jsindex.js的结构完全取决于您。如图所示,您可以在单个文件中执行上述所有操作,或者将 https/fs 要求拆分为 index.js,并将应用程序配置为应用程序.js - 我推荐这种方法,因为如果您决定使用像 nginx 这样的反向代理来处理 ssl 而不是 node,它将允许您更改(通常较小的)index.js 文件。

相关内容

  • 没有找到相关文章

最新更新