user3272483
user3272483

Reputation: 408

Receiving client data using nodejs tcp server

I want to receive data from a client that is sending data to my server. This is my code that inserts the incoming data into msql

var net = require('net');
var mysql = require('mysql');
var randomstring = require("randomstring");

var server = net.createServer(function(socket) {
    socket.write('Echo server\r\n');
    socket.pipe(socket);
});
 socket.on('data', function (data) {

var connection = mysql.createConnection({
  host     : 'seizedserver.com',
  user     : 'federal',
  password : '123456',
  database : 'hanging_tree'
});

connection.connect();
/*
connection.query('SELECT data from gps', function(err, rows) {
  if (err) throw err;

  console.log('The solution is: ', rows[0]);
});
*/
var post  = {data: data};
var query = connection.query('INSERT INTO gps SET ?', post, function(err, result) {
});
console.log(query.sql); 

connection.end();
  });
server.listen(1337, '127.0.0.1');

The plan is to insert incoming data into the mysql table i have created but i am not sure i am using the data event correctly.

Am i using the data event correctly?.

I get this error when i run my script with forever

/var/www/html/server.js:9
 socket.on('data', function (data) {
 ^
ReferenceError: socket is not defined
    at Object.<anonymous> (/var/www/html/server.js:9:2)
    at Module._compile (module.js:456:26)
    at Object.Module._extensions..js (module.js:474:10)
    at Module.load (module.js:356:32)
    at Function.Module._load (module.js:312:12)
    at Function.Module.runMain (module.js:497:10)
    at startup (node.js:119:16)
    at node.js:902:3
error: Forever detected script exited with code: 8

Upvotes: 2

Views: 2058

Answers (1)

Thomas Stringer
Thomas Stringer

Reputation: 5862

socket is only defined in the callback of your server:

var server = net.createServer(function(socket) {
    socket.write('Echo server\r\n');
    socket.pipe(socket);
});

 // socket is undefined here
 socket.on('data', function (data) {

var connection = mysql.createConnection({
  host     : 'seizedserver.com',
  user     : 'federal',
  password : '123456',
  database : 'hanging_tree'
});

Should be:

var server = net.createServer(function(socket) {
    socket.write('Echo server\r\n');

    // socket is defined here and in scope
    socket.on('data', function (data) {

    var connection = mysql.createConnection({
      host     : 'seizedserver.com',
      user     : 'federal',
      password : '123456',
      database : 'hanging_tree'
    });

    socket.pipe(socket);
});

Upvotes: 3

Related Questions