发布到nodejs并返回结果

时间:2011-10-07 02:22:36

标签: node.js cross-domain jsonp jquery-post

我一直在google搜索从我的网站上托管的客户端j发送到nodejs服务器的时间,而不是将这些结果返回给我的客户端。

这是我想要完成的一个例子:

<html>
<head>
<script type="text/javascript">
var my_id = <?=$myuserid;?>;
$(function(){
    $.ajax({
        url: 'http://mydomain.com:8001/get_friends',
        dataType: 'JSONP',
        type: 'POST',
        crossDomain: true,
        data: {
            id: my_id
        },
        success: function(data){
            if(data.error===true){
                alert(data.msg);
            } else {
                alert(data.users);
            }
        }
    });
});
</script>
</head>
<body>
</body>
</html>

比NodeJS文件:

var http = require('http'),
    url = require('url'),
    mysql = require('mysql'),
    sys = require('sys');
var client = mysql.createClient({
    user: 'root',
    password: 'password',
});

http.createServer(function(request, response){
    client.query('USE mydatabase');
    client.query(
        'SELECT * FROM buddy_list WHERE user_id = "This is where I need my post to go"',
        function selectCb(err, results, fields){
            if(err){
                throw err;
            }
            response.writeHead(200, { 'Content-Type' : 'application/json' });
            "Here I need it to feed back results to client script."
            response.end();
            client.end();
    })
}).listen(8001);

2 个答案:

答案 0 :(得分:2)

除了输入卫生问题,以下是解决这个问题的方法:

http.createServer(function(request, response){
    request.on('data', function(chunk) {
        dataInput = chunk.toString();
        client.query('USE mydatabase');
        client.query(
            'SELECT * FROM buddy_list WHERE user_id = ' + dataInput,
            function selectCb(err, results, fields){
                if(err){
                    throw err;
                }
                response.writeHead(200, { 'Content-Type' : 'application/json' });
                "Here I need it to feed back results to client script."
                response.end();
                client.end();
        })

    })
}).listen(8001);

答案 1 :(得分:1)

response.writeHead(200, { 'Content-Type' : 'application/json' });
response.send( JSON.stringify(results) );

我没试过这个,但它看起来像你想要的。我不确定结果,字段有什么或者是否需要更多数据操作。我假设“结果”是一个JSON对象。