如何根据请求解析原始数据?

时间:2013-04-12 00:20:49

标签: javascript node.js

我有一个表单,用于向使用Ajax的数据库提交post data,如下所示:

function markAsRead(id) {
    console.log('Triggered');
    $.ajax({
        type: 'POST',
        url: '/admin/assessment.html',
        data: id,
        success: function(data) {
            if (data.error) {
                console.log('We had an error.');
            } else if (data.success) {
                console.log('Marker updated.');
            }
        }
    })
}

(function() {
    var element = document.getElementsByName('markAsRead');
    for(var i = 0; i < element.length; i += 1) {
        element[i].addEventListener('click', function(e)  { e.preventDefault;
            markAsRead(this.getAttribute('data-value'));
        });
    }
})();

我的页面上有多个Anchor,例如:

<a href="#" name="markAsRead" data-value="5135135">Mark As Read</a>

我只是想知道事情的Node.js方面,我如何解析这些数据,我试过:

var id = req.body.markAsRead;

  console.log('Data is ' + id);

但它只是说未定义。有关如何解析此请求数据的任何信息都很棒。谢谢! (Anchor不在任何形式内)

1 个答案:

答案 0 :(得分:1)

首先,您应该使用命名参数从客户端发布数据,或者使用比字符串更结构化的内容。

$.ajax({
    type: 'POST',
    url: '/admin/assessment.html',
    data: { id: id },
    success: function(data) {
        if (data.error) {
            console.log('We had an error.');
        } else if (data.success) {
            console.log('Marker updated.');
        }
    }
})

其次,当您解析节点端的req.body时,您正在解析作为请求正文发送的字符串,其中包含您的参数 {id:'somevalue'} 。你可以自己解析这个问题,但我猜你在节点的支持middleware stack的http.Server实现之上使用的是 express 或其他抽象。我建议使用connect bodyParser()中间件,它将req.body字符串转换为具有已发布属性的对象。这将使您在节点中的请求处理程序中可以使用 req.body.id