json - 尝试从 Node.js 将文档插入 CouchDB 时出现 ' bad_request invalid_json' 错误

标签 json node.js couchdb

我正在尝试将文档插入 CouchDB。执行此代码时,CouchDB 返回以下错误:

STATUS: 400    
BODY: {"error":"bad_request","reason":"invalid_json"}    

我的代码:

var http = require('http')


var options = {
"host": "localhost",
"port": "5984",
"path": "/chinese",
"headers": {"content-type": "application/json"},
"method": "PUT",
"body": JSON.stringify({
    "_id":"rabbit",
    "_rev":"2-c31d8f403d44d1082b3b178ebef8d329",
    "Subject":"I like Plankton"
})
};

var req = http.request(options, function(res) {
  console.log('STATUS: ' + res.statusCode);
  res.setEncoding('utf8');
  res.on('data', function (chunk) {
    console.log('BODY: ' + chunk);
  });
});

req.write('data\n');
req.end();

出了什么问题?

编辑:我需要更新数据,所以我将 POST 替换为 PUT。

最佳答案

因为您正在编写 'data\n' 作为请求的正文,而这确实不是有效的 JSON。

您的意思可能是:

req.write(JSON.stringify({"data": "somedata"}));

而不是将其作为选项的 body 参数传递。

关于json - 尝试从 Node.js 将文档插入 CouchDB 时出现 ' bad_request invalid_json' 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11647656/

相关文章:

java - 当 JSONArray 大于 261​​ 时应用程序崩溃

ios - 从 iOS 5 中包含 .SVC?wsdl 文件的 URL 获取 JSON 数据?

javascript - CommonJS 和 RequireJS 哪个更适合 JavaScript 游戏开发?

json - CouchDB 中奇怪的 JSON

java - 如何在 Java 8 中迭代 JSONArray

php - Laravel json 仅转换为数组数字 PHP

javascript - node.js setInterval 在自定义模块中不起作用

javascript - Sequelize 实例方法 save() 并发行为

recursion - CouchDB "_changes"监听器更新文档,这会触发另一个更改

javascript - 将参数传递给 CouchDb 中的映射函数