2

サーバーのポート番号とは異なるポート番号を socket.io に指定すると、アプリケーションが動作します。作業コードは次のようになります。

これは私の app.js ファイルです:

var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var mongoose = require('mongoose');
var configDB = require('./config/database.js');
var session = require('express-session');
var passport = require('passport');

var routes = require('./routes/index');
var auth = require('./routes/auth.js');

var app = express();

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

// uncomment after placing your favicon in /public
//app.use(favicon(__dirname + '/public/favicon.ico'));
app.set(process.env.PORT || 1337);
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(require('stylus').middleware(path.join(__dirname, 'public')));
app.use(express.static(path.join(__dirname, 'public')));
app.use(session({ secret: 'mysessionsecret' }));
app.use(passport.initialize());
app.use(passport.session());

mongoose.connect(configDB.url);

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

// catch 404 and forward 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: {}
    });
});

var talk = require('./socket/talk.js')(app);

module.exports = app;

これは私の talk.js ファイルです:

var init = function (app){    
    var server = require("http").createServer(app).listen(3000);
    var io = require("socket.io").listen(server);

    var socketioJwt = require("socketio-jwt");
    var jwtSecret = require('../config/jwtSecret');

    console.log("init");

    io.set("authorization", socketioJwt.authorize({
        secret: jwtSecret,
        handshake: true
    }));

    io.sockets.on("connection", function (socket) {
        console.log("connected");
        socket.on("send", function (data) {
            console.log(data);
            var username = data.username;
            var message = data.message;
            var datetime = data.datetime;

            socket.broadcast.emit("send", data);
        });
        socket.on("busy", function () {
            socket.emit("busy");
            socket.broadcast.emit("busy");
        });
        socket.on("free", function () {
            socket.emit("free");
            socket.broadcast.emit("free");
        });
    });
}

module.exports = init;

これは、index.ejs のスクリプト タグです。

<script src="http://localhost:3000/socket.io/socket.io.js"></script>

そして最後に、これはクライアントからの私の io 接続です:

socket = io("http://localhost:3000/",{
            query: 'token=' + tok
        });

これは機能しますが、サイトを Azure に公開したいのですが、Azure Web サイトに異なるポートをリッスンさせることができないという問題があります。少なくとも私は無理だと思います。

私が試した多くのことの 1 つは、talk.js ファイルを次のように変更することです。

var init = function (app){    
    var server = require("http").createServer(app).listen(app.get('port'));
    var io = require("socket.io").listen(server);
...

しかし、うまくいきません。私はいつもhttp://localhost/socket.io/socket.io.js not found

index.ejs ファイルの script タグをこれに変更すると、

<script src="http://cdn.socket.io/socket.io-1.2.1.js"></script>

socket.io.js ファイルがロードされますが、クライアント側から接続すると、連続して 404 not found エラーが発生します。

オンラインで多くのソリューションを見ましたが、どれも機能しません。私は自分が間違っていることを本当に知りません。

4

1 に答える 1