gpt4 book ai didi

node.js - Primus 与 Express

转载 作者:太空宇宙 更新时间:2023-11-03 22:01:37 25 4
gpt4 key购买 nike

我想使用Primus与 express 。 Primus 作为 websockets 的抽象层。我使用 Primus 示例工作正常 - 我使用基本 Express 示例 - 工作正常。但不知何故我可以让他们一起工作。

index.html(只是标准的 primus 示例 html)和 primus.js 位于文件夹 ./public

这就是我正在做的事情。

var express = require('express');
var Primus = require('primus');
var http = require('http');
var path = require('path');
var app = express();

var server = require('http').createServer(app)
, primus = new Primus(server, { transformer: 'engine.io' });


app.set('port', process.env.PORT || 3000);
app.use(express.logger('dev'));
app.use(express.json()); // to support JSON-encoded bodies
app.use(express.urlencoded()); // to support URL-encoded bodies
app.use(express.methodOverride());

app.use(app.router);
app.use(express.static(__dirname + '/public'));


// development only
if ('development' == app.get('env')) {
app.use(express.errorHandler());
}

primus.on('connection', function connection(spark) {
console.log('new connection');
spark.write({ Welcome: 'Hello!' });
});

primus.save(__dirname +'/public/primus.js');

/* the normal express start
http.createServer(app).listen(app.get('port'), function(){
console.log('Express server listening on port ' + app.get('port'));
});
*/

server.listen(app.get('port'), function(){
console.log('Express server listening on port ' + app.get('port'));
});

访问时的输出

http://localhost:3000/index.html


Express server listening on port 3000
GET /index.html 200 73ms - 5.22kb

index.html 服务正确。但没有显示对 primus.js 的请求。并且index.html在get primus.js上显示400错误

当我禁用上面代码中的 primus 部分并使用正常的快速启动时,我得到以下输出:

Express server listening on port 3000
GET /index.html 200 79ms - 5.22kb
GET /primus.js 200 69ms - 96.54kb

所以一切都正确。 Prmius 在客户端上工作,但当然服务器端没有人回答,因为我禁用了 primus。

知道出了什么问题吗?

最佳答案

我认为出现这个问题是因为 Primus 拦截了所有以 /primus 开头的请求,因此 Express 无法提供 primus.js 文件。

我还假设您的 HTML 文件中有类似以下内容的内容:

<script src="/primus.js"></script>

尝试将其替换为:

<script src="/public/primus.js"></script>

然后替换这一行:

app.use(express.static(__dirname + '/public'));

这个:

app.use('/public', express.static(__dirname + '/public'));

更新

由于我们更改了静态文件 URI,因此我们必须手动提供 index.html:

app.get('/', function(req, res) {
res.sendfile(__dirname + '/public/index.html');
});

关于node.js - Primus 与 Express,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21967958/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com