web-dev-qa-db-ja.com

socket.ioを使用したExpress 4.0ルートの構成

新しいExpressアプリケーションを作成しました。それは私のためにapp.jsを生成し、それから私はsocket.ioをもたらす次のindex.jsを作成しました:

var app = require('./app');
server=app.listen(3000);

var io = require('socket.io');
var socket = io.listen(server, { log: false });

socket.on('connection', function (client){
    console.log('socket connected!');
});

誰かがroutesファイル内のsocket.ioにアクセスする方法をアドバイスできますか?

参考までに、デフォルトで生成されたapp.jsを以下に示します。

var express = require('express');
var path = require('path');
var favicon = require('static-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');

var routes = require('./routes/index');
var users = require('./routes/users');

var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');

app.use(favicon());
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded());
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.use('/', routes);
app.use('/users', users);

/// catch 404 and forwarding to error handler
app.use(function(req, res, next) {
    var err = new Error('Not Found');
    err.status = 404;
    next(err);
});

/// error handlers

// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
    app.use(function(err, req, res, next) {
        res.status(err.status || 500);
        res.render('error', {
            message: err.message,
            error: err
        });
    });
}

// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
    res.status(err.status || 500);
    res.render('error', {
        message: err.message,
        error: {}
    });
});


module.exports = app;
11
Ben

SocketIOは、ソケットで機能するルートでは機能しません。

これは、特別に作成された express-io を代わりに使用するか、リアルタイムWebアプリを構築している場合は、すでにsocketIOが統合されている sailsjs を使用してみることをお勧めしますそれ。

これをメインapp.js

app = require('express.io')()
app.http().io()

app.listen(7076)

次に、ルートで次のようにします。

app.get('/', function(req, res) {
    // Do normal req and res here
    // Forward to realtime route
    req.io.route('hello')
})

// This realtime route will handle the realtime request
app.io.route('hello', function(req) {
    req.io.broadcast('hello visitor');
})

express-ioのドキュメントはこちら を参照してください。

または、あなたが本当にexpress + socketioにこだわりたいならこれを行うことができます

あなたのapp.js

server = http.createServer(app)
io = require('socket.io').listen(server)
require('.sockets')(io);

次に、ファイルを作成しますsockets.js

module.exports = function(io) {

    io.sockets.on('connection', function (socket) {
        socket.on('captain', function(data) {
            console.log(data);
            socket.emit('Hello');
        });
    });
};

次に、それをルート/コントローラに呼び出すことができます。

32
majidarif

ルート:

const Router = require('express').Router

const router = new Router();

router.get('/my-route', (req, res, next) => {
    console.log(req.app.locals.io) //io object
    const io = req.app.locals.io
    io.emit('my event', { my: 'data' }) //emit to everyone
    res.send("OK")
});

module.exports = router

メインファイル:

const app = require('express')()
const server = require('http').Server(app);
const io = require('socket.io')(server)
const myroute = require("./route") //route file dir

app.use(myroute);

server.listen(3000, () => {
    console.log('¡Usando el puerto 3000!');
});

app.locals.io = io
1
Armando Rueda