2016-05-17 143 views
1

我會先說我發現了這個網站上發佈的幾個類似問題。儘管如此,它們都不適用於我的情況。socket.io發射三次發射

我有一個服務器和客戶端(與node.js/socket.io規範一樣),並且在按下按鈕時調用會發出套接字事件。這工作正常...除了似乎排放三次(至少服務器運行三次函數)。在這一點上,我一直盯着代碼太長,需要另一套眼睛。

希望有人有一個想法。

客戶端代碼:

importJS('/js/pages/admin_base.js',function(){ 
    var restartLMC = function(io){ 
     toggleLoad(); 
     var user = localStorage.getItem('User'); 
     io.emit('restart_request',{session: user}); 
    }; 
    AdminIO = new io('http://localhost:26266'); 
    AdminIO.on('restart_success',function(dat){ 
     toggleLoad(); 
     dropInfo(dat); 
    }); 
    AdminIO.on('sendError',function(dat){ 
     dropInfo(dat,{level: 'error'}); 
    }); 
    AdminIO.on('restart_fail',function(dat){ 
     toggleLoad(); 
     dropInfo(dat,{level: 'error'}); 
    }); 
    $('#restart').on('click',function(){ 
     restartLMC(AdminIO); 
    }); 
}); 

管理員代碼:

process.stdout.write('\033c'); 
console.log('\x1b[36m', "Admin server starting...", '\x1b[0m'); 
var 
    ini = require('node-ini') 
    , conf = ini.parseSync('../config.ini') 
    , CS = require('../lm_modules/CoreSync.js') 
    , CoreSync = new CS() 
    , checkSession = function (session, callback) { 
      var res; 
      if (!CoreSync) { throw "Fatal error, there is no connection to the Core service!"; } 
      if (CoreSync.sessions) { 
       if (CoreSync.sessions[session]) { 
        res = CoreSync.sessions[session]; 
        callback(res); 
       } 
       else { 
        CoreSync.sync('session', function (err, dat) { 
         if (CoreSync.sessions[session]) { 
          res = CoreSync.sessions[session]; 
          callback(res); 
         } else { res = false; callback(res); } 
        }); 
       } 
      } else { 
       res = false; callback(res); 
      } 
      if (res === "undefined") { callback(false); } 
     } 
    , runCMD = function(cmd,errCB,callback){ 
     var 
      command 
      , args; 
     if(cmd.cmd){ command = cmd.cmd; } else { command = cmd; } 
     if(cmd.args){ args = cmd.args; } 
     const spawn = require('child_process').spawn;   
     const ex = spawn(command, args); 
     ex.stdout.on('data', (data) => { 
      callback(data); 
     }); 
     ex.stderr.on('data', (data) => { 
      errCB(data); 
     }); 
     ex.on('close', (code) => { 

     }); 
    }  
    , executeCMD = function(cmd,callback){ 
     const exec = require('child_process').exec 
       , cdw = (__dirname + '/../'); 
     exec(cmd, {cwd: cdw}, (err, stdout, stderr) => { 
      if (err) { 
       callback(err,null); 
       return; 
      } 
      callback(stderr,stdout); 
     }); 
    }  
    , io = require('socket.io').listen(26266) // can use up to 26485 

console.log('\x1b[32m', "Admin server started.", '\x1b[0m'); 
console.log("Admin server listening at " + "http://" + conf["Server"]["binding"] + ":26266"); 
io.on('connection', function (socket) { 
    socket.on('restart_request', function(req){ 
     console.log('Recieved restart request');  
     var success = false 
      , session = JSON.parse(req.session) 
      , sessionID = session.sessionID; 
     checkSession(sessionID, function (ses) { 
      if (ses === false) { console.error('CheckSession failed: No session exists'); return; } 
      if (ses.user.uuid !== session.uuid) { console.error('CheckSession failed: UUID mismatched'); return; } 
      if (ses.user.role < conf['Permissions']['lm_restart']){ socket.emit('restart_fail','Insufficient permissions.'); return; } 
      if(process.platform === 'win32'){    
       executeCMD('cd',function(err,res){ 
        var errSent = false; 
        if(err){       
         console.error(err); 
         if(!errSent){ socket.emit('sendError','Restart failed'); } 
         errSent = true; 
         if(res === null){return;} 
        } 
        console.log(res); 
        socket.emit('restart_success','LM successfully restarted.'); 
       });     
      } 
      else if(process.platform === 'linux'){ 

      } 
     }); 
    }); 
}); 

回答

0

對於那些你誰可能已經看到了這一點,並發現這是一個奇怪的問題/情形......我發現了兩個環節進行。

第一部分是$()。on綁定。出於某種原因(即使在js代碼中多次調用它),在綁定前添加unbind()部分地解決了問題......它將多餘的部分從3減少到2(直到我開始另一個服務器應用程序,然後它回到了三個......)

我發現的另一部分是(由於某種原因)socket.io連接重複多次,因爲運行的套接字服務器。關於這個問題的更多細節here ......我相信一旦找到這個原因,我的問題就會得到解決。