Socket возвращает '[Object object]' - PullRequest
0 голосов
/ 26 апреля 2019

Я попробовал hooours и не могу найти какое-либо решение, я пытаюсь проанализировать данные в файл моего сервера, который помещает содержимое в базу данных mysql, но всегда выводит только [объект Object], и я серьезно не могу найти какое-либо решение для этого. Буду признателен за любую помощь.

Main.js

   "use strict";
$(document).ready(function() {
    var socket = io.connect(":2096");
        var s = socket;
        function connect() {
                if (!socket) {
                    if (hash == "" || hash != "") {}
            socket = io(":2096");
            s.on('connect', function() {
                if (hash != "") {}
                s.emit('hash', hash);
            });
        }
}
    connect();
});
$(document).on('click', '.adm-req', function(data) {
    var name1 = $('#firstname');
    var lastname = $('#lastname');
    var userid = $('#userid');
    var pin = $('#pin');
    var password = $('#password');
    socket.emit('--get-request_adm', {
        firstname: name1,
        lastname: lastname,
        userid: userid,
        pin: pin,
        password: password
    });  
});

Server.js

var mysql = require('mysql');
var log4js = require('log4js');
var request = require('request');
var fs = require('fs');
var crypto = require('crypto');
var md5 = require('md5');
var sha256 = require('sha256');
var math = require('mathjs');
var logger = log4js.getLogger();
var nodemailer = require('nodemailer');


var express = require('express');
var app = express();

var httpServer = require('https').createServer(options, app)
var io = require('socket.io')(httpServer);
httpServer.listen(2096);

io.on('connection', function(socket) {  
    socket.on('--get-request_adm', function(data) {
        pool.query('INSERT INTO `users` SET `firstname` = "'+data.firstname+'"')
    });
});
function query(sql, callback) {
    if (typeof callback === 'undefined') {
        callback = function() {};
    }
    pool.getConnection(function(err, connection) {
        if (err) return callback(err);
        connection.query(sql, function(err, rows) {
            if (err) return callback(err);
            connection.release();
            return callback(null, rows);
        });
    });
}

Ответы [ 2 ]

0 голосов
/ 26 апреля 2019

Проблема с этим

var name1 = $('#firstname');
// etc

Возвращает объект jQuery , поэтому строковое значение равно [object object]

Попробуйте получить значение входных данных (при условии, конечно, что они являются входными данными), используя jquery.val ()

$(document).on('click', '.adm-req', function(data) {
    var name1 = $('#firstname').val();
    var lastname = $('#lastname').val();
    var userid = $('#userid').val();
    var pin = $('#pin').val();
    var password = $('#password').val();
    socket.emit('--get-request_adm', {
        firstname: name1,
        lastname: lastname,
        userid: userid,
        pin: pin,
        password: password
    });  
});

в качестве альтернативы, если вам нужны объекты jQuery по какой-то другой причине

$(document).on('click', '.adm-req', function(data) {
    var name1 = $('#firstname');
    var lastname = $('#lastname');
    var userid = $('#userid');
    var pin = $('#pin');
    var password = $('#password');
    socket.emit('--get-request_adm', {
        firstname: name1.val(),
        lastname: lastname.val(),
        userid: userid.val(),
        pin: pin.val(),
        password: password.val()
    });  
});
0 голосов
/ 26 апреля 2019

Вы хотите использовать val ue firstname, а не сам объект - поэтому получите это, когда объявите:

var name1 = $('#firstname').val();

Сделайте это для всех ваших объявлений, чтобы получить значение.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...