2017-07-02 10 views
1

複数の条件でNodeJSでスクリプトを作成しました。 NodeJS Serverを使用してconsole.logをWebページにエクスポート/印刷したいとします。nodejs console.logをHTTPに出力

function myfunction() { 
    app('Some text', 'ALERT!', function(err, remaining) { 
     if (err) throw err; 
     console.log('Some text.'); 

これは可能ですか?私はどこでも検索しました。

ありがとうございます!

+0

なぜあなたは、クライアント側のWebページにサーバーからのログを印刷したいのですか? –

+0

PRTG(監視ツール)でそれらを使用したいので – user3130478

+0

これらの種類のソケットを使用してみてください。 –

答えて

1

console.log(...)の結果をWebページにエクスポート/印刷するには、console.logを無効にして、サーバーコンソールで印刷する前にメッセージを出力させることができます。その後、Web Socketを使用してブラウザにメッセージが送信され、ページに印刷/使用されます。

コードの例を以下に示します。

サーバー側:

var app = require('express')(); 
var http = require('http').Server(app); 
var io = require('socket.io')(http); 
var port = process.env.PORT || 3000; 

var events = require('events'); 
var eventEmitter = new events.EventEmitter(); 

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

eventEmitter.on('logging', function(message) { 
    io.emit('log_message', message); 
}); 

http.listen(port, function(){ 
    console.log('listening on *:' + port); 
}); 

// Override console.log 
var originConsoleLog = console.log; 
console.log = function(data) { 
    eventEmitter.emit('logging', data); 
    originConsoleLog(data); 
}; 

// code for test. 
setInterval(function() { 
    console.log('X: ' + Math.random()); 
}, 2000); 

ブラウザ側:

<!doctype html> 
<html> 
    <head> 
    <title>Example</title> 
    </head> 
    <body> 
    <ul id="messages"></ul> 
    <script src="https://cdn.socket.io/socket.io-1.2.0.js"></script> 
    <script src="https://code.jquery.com/jquery-1.11.1.js"></script> 
    <script> 
     $(function() { 
     var socket = io(); 
     socket.on('log_message', function(msg){ 
      $('#messages').append($('<li>').text(msg)); 
     }); 
     }); 
    </script> 
    </body> 
</html> 
+0

例をありがとう!スクリプトを使用すると、次のエラーが発生します。(ノード)警告:可能EventEmitterメモリリークが検出されました。 11ログリスナーが追加されました。 limitを増やすにはemitter.setMaxListeners()を使用してください。 – user3130478

+0

@ user3130478これは、io接続があるたびに、新しい 'logging'イベントリスナーが追加されるためです。私は答えのコードを編集し、たった一つの 'logging'イベントリスナを残しました。これは 'console.log(...)'ステートメントブロードキャストメッセージをすべてのクライアントブラウザに送ることに注意してください。 – shaochuancs

関連する問題