CouchDB cURL Windows Command Line Invalid JSON

2019-02-11 20:10发布

Running the following command from a Windows command line using cURL attempting to post a new document to an existing CouchDB database (named test) fails:

curl -H "Content-Type: application/json" -X POST "http://127.0.0.1:5984/test" -d {"valid":"json"}

It returns the error:

{"error":"bad_request","reason":"invalid_json"}

The JSON is valid so what gives?

2条回答
相关推荐>>
2楼-- · 2019-02-11 20:20

The answer is related to the formatting of the JSON string on the command line. Even though it is proper JSON when you type it, the command line, it seems, must reformat it before sending it.(Maybe someone else can explain why it does this in more detail.) To fix this you need to escape your quotations in the command line like so:

curl -H "Content-Type: application/json" -X POST "http://127.0.0.1:5984/test" -d {"""valid""":"""json"""}

See the extra quotation marks? This should work and return "ok:true" with an id and revision number.

查看更多
The star\"
3楼-- · 2019-02-11 20:33

You have to quote also the whole statement to support spaces like: -d "{\"title\":\"There is Nothing Left to Lose\" , \"artist\":\"Foo Fighters\"}"

查看更多
登录 后发表回答