Primus with Express



我想将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

索引.html正确服务。 但是没有对Primus的请求.js出现。索引.html在获取 primus 时显示 400 个错误.js

当我在上面的代码中禁用 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');
});

最新更新