2013-01-06 57 views
2

我有一個node.js服務器腳本,它使用web套接字從串行端口讀取數據,並在瀏覽器上顯示數據。服務器腳本非常好,因爲它可以在瀏覽器上正確顯示實時數據。這也意味着websockets也正常工作。當我嘗試使用Flot來顯示實時圖表以可視化數據時,真正的問題就開始了。服務器會拋出錯誤消息 - 調試 - 提供靜態內容/socket.io.jsFlot不能使用node.js

這裏是我的服務器代碼:

// It captures data from serial port and displays it in web page. 
var http = require('http').createServer(handler); 
var io = require('socket.io').listen(http); 
var sys = require('sys'); 
var fs = require('fs'); 
var clients = []; 
http.listen(8000); 

var SerialPort = require('serialport2').SerialPort; 
var portName = 'COM10'; 
var sp = new SerialPort(); // instantiate the serial port. 
sp.open(portName, { // portName is instatiated to be COM3, replace as necessary 
     baudRate: 9600, // this is synced to what was set for the Arduino Code 
     dataBits: 8, // this is the default for Arduino serial communication 
     parity: 'none', // this is the default for Arduino serial communication 
     stopBits: 1, // this is the default for Arduino serial communication 
     flowControl: false // this is the default for Arduino serial communication 
    }); 
function handler(request, response) { 
     response.writeHead(200, { 
     'Content-Type':'text/html' 
    }); 
var rs = fs.createReadStream(__dirname + '/template2.htm'); 
sys.pump(rs, response); 
}; 

var buffer ; //contains raw data 
var dataStore = "" ; // To hold the string 

io.sockets.on('connection', function(socket) { 
var username; 
clients.push(socket); 
socket.emit('welcome', {'salutation':'TMP36 Sensor output!'}); 

sp.on('data', function (data) { // call back when data is received 
    buffer = data.toString(); 
    // check for end character in buffer 
    for(i=0; i<buffer.length; i++) 
    { 
     if(buffer[i] != "N") 
     { 
      //store it in data 
      dataStore = dataStore + buffer[i];     
     } 
     if(buffer[i] == "N") 
     { 
      //spit the data 
      //console.log(dataStore);   
      //socket.emit('data', {'salutation':dataStore});  
      socket.emit('data', dataStore);  
      // //initialize data to null  
      dataStore = ""; 
     } 
    }   
    });  
}); 

下面是一個嘗試的客戶端代碼使用海軍報顯示實時圖表

<!DOCTYPE html> 
<html lang='en'> 
<head> 
     <title>Chat</title> 
    <link type="text/css" href="/css/smoothness/jquery-ui-1.8.20.custom.css" rel="Stylesheet" /> 
     <script type='text/javascript'  
      src='http://ajax.googleapis.com/ajax/libs/jquery/1.4.3/jquery.min.js'></script> 
    <script language="javascript" type="text/javascript" src="../3rdParty/flot/jquery.js"></script> 
    <script language="javascript" type="text/javascript" src="../3rdParty/flot/jquery.flot.js"></script> 
    <script src="//localhost:8000/socket.io/socket.io.js"></script> 

    <script type="text/javascript"> 
    $(function() {   
     // Initialize Flot data points 
     var totalPoints = 300; 
     var res = []; 
     function getInitData() { 
      // zip the generated y values with the x values 
      for (var i = 0; i < totalPoints; ++i){ 
       res.push([i, 0]); 
      } 
      return res; 
     } 

     // Options for Flot plot 
     var options = { 
      series: { shadowSize: 0 }, // drawing is faster without shadows 
      yaxis: { min: 0, max: 100 }, 
      xaxis: { show: false } 
     }; 
     var plot = $.plot($("#placeholder"), [ getInitData() ], options); 

     // Update the JQuery UI Progress Bar 
     $("#progressbar").progressbar({ 
      value: 0 
     }); 

     //var socket = io.connect(); 
     //var socket = io.connect('http://localhost:8000'); 
     //var socket = io.connect(document.location.href); 
     var socket = io.connect('http://10.0.0.2:8000'); 

     //This block is executed when data is received from server 
     socket.on('data', function(msg) {     
      // Put sensor value to the 'sensor_value' span 
      //var val = data.salutation; 
      var val = msg; 
      $('#sensor_value').html(val); 

      // Push new value to Flot Plot 
      res.push([totalPoints, val]); // push on the end side 
      res.shift(); // remove first value to maintain 300 points 
      // reinitialize the x axis data points to 0 to 299. 
      for (i=0;i<totalPoints;i++) { res[i][0] = i; } 

      // Redraw the plot 
       plot.setData([ res ]); 
       plot.draw(); 
       // Update JQuery UI progress bar. 
       $("#progressbar").progressbar({ 
        value: val 
       }); 
     }); 

    }); 
    </script>  
</head> 
<body> 
    <h1>Temperature Monitor</h1> 
    <div role="main"> 
     Potentiometer Value: <span id="sensor_value"></span><br/> 
    <div id="progressbar" style="width:600px;height:50px;"></div><br/> 
    Graph:<br/> 
     <div id="placeholder" style="width:600px;height:300px;"></div><br/>   
</body> 
</html> 

誰能幫助我,爲什麼海軍報不工作在我的設置? 還有我運行服務器和客戶端相同的機器上它是Windows 7

在Chrome調試器,我可以看到以下消息:

Resource interpreted as Script but transferred with MIME type text/html: "http://localhost:8000/3rdParty/flot/jquery.js". :8000/:6 
Resource interpreted as Script but transferred with MIME type text/html: "http://localhost:8000/3rdParty/flot/jquery.flot.js". :8000/:6 
Resource interpreted as Stylesheet but transferred with MIME type text/html: "http://localhost:8000/css/smoothness/jquery-ui-1.8.20.custom.css". localhost:5 
Uncaught SyntaxError: Unexpected token < jquery.js:2 
Uncaught SyntaxError: Unexpected token < jquery.flot.js:2 
Uncaught TypeError: Object function (i,r){return new b.fn.init(i,r)} has no method 'plot' localhost:31 

任何幫助將非常高度讚賞。

乾杯! AN

+1

這些錯誤意味着兩件事:1)您的服務器沒有使用正確的MIME類型提供js文件。 2.)jquery.js和flot.js都沒有被正確解釋,並帶有「Unexpected token」錯誤。請按照@thtsigma的建議在下面做,並確保您可以從您的網絡服務器正確地獲取這些js文件。 – Mark

回答

1

我只想發表評論,但我沒有足夠的代表。也許這會幫助,我不知道。

修改

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

到:

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

擺脫了調試事情對我來說......也動

var socket = io.connect('http://localhost:8000'); 

是正確下面的功能似乎允許控制檯吐出一些更多的調試語句。

<script type="text/javascript"> 
$(function() {   
    var socket = io.connect('http://localhost:8000'); 
    // Initialize Flot data points 
    var totalPoints = 300; 
+0

Hi thigigma,在做出上述兩個更改後,我可以看到更多的調試消息。調試消息指示正在從串行端口接收數據。但實時圖形仍未顯示。 –

+0

也在Chrome調試器中,我可以看到以下錯誤消息:** Uncaught TypeError:Object# has no method'progressbar'** Uncaught TypeError:Object function(i,r){return new b.fn.init(i,r )}沒有方法'plot' –

+1

啊,我不知道你沒有得到一個圖表顯示。您可以通過檢查瀏覽器中的源代碼並單擊該腳本的鏈接並查看它是否顯示腳本的來源來檢查以確保腳本正在加載。 – thtsigma