使用 aurelia fetch 客户端将 400 状态发布到 _user 数据库的 couchdb 响应

couchdb response with 400 status posting to _user db using aurelia fetch client

这有点奇怪。我对 couchdb 2.0 进行休息 post 调用以更新用户数据库,然后返回 401 状态消息 "error=bad_request" 和 "reason=Referer header must match host."

但是,如果我将 "post" 更改为 "put",那么它很高兴并且 201 的 returns 状态符合预期。我可以继续使用 puts,但这不是标准。

建议?

POST http://localhost:5984/_users/org.couchdb.user:test1 HTTP/1.1
Host: localhost:5984
Connection: keep-alive
Content-Length: 364
Pragma: no-cache
Cache-Control: no-cache
Origin: http://localhost:9000
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 Safari/537.36
content-type: application/json
Accept: */*
DNT: 1
Referer: http://localhost:9000/
Accept-Encoding: gzip, deflate, br
Accept-Language: en-US,en;q=0.8
Cookie: io=YBMMIY0pejGjeHV9AACO; AuthSession=foo

{
  "_id":"org.couchdb.user:test1",
  "_rev":"1-8e2136e07f62238327f87d1ae54a29df",
  "type":"user","roles": "user"],
  "name":"test1",
  "email":"test1@foo.bar",
  "fullName":"Test1 esq",
  "phone":"555-555-5555",
  "id":"org.couchdb.user:test1",
  "password_scheme":"pbkdf2",
  "iterations":10,
  "derived_key":"0e076f6f85f1389fd90ff181d433e1438e8e30a4",
  "salt":"37f590de042f07956f6cc11b8a9eb012"
}

回应

HTTP/1.1 400 Bad Request
Access-Control-Allow-Credentials: true
Access-Control-Allow-Origin: http://localhost:9000
Access-Control-Expose-Headers: content-type, cache-control, accept-ranges, etag, server, x-couch-request-id, x-couch-update-newrev, x-couchdb-body-time
Cache-Control: must-revalidate
Connection: close
Content-Length: 67
Content-Type: application/json
Date: Thu, 29 Dec 2016 23:15:25 GMT
Server: CouchDB/2.0.0 (Erlang OTP/17)
X-Couch-Request-ID: b45ec52b5c
X-CouchDB-Body-Time: 0

{"error":"bad_request","reason":"Referer header must match host."}

**This works**

PUT http://localhost:5984/_users/org.couchdb.user:test1 HTTP/1.1
Host: localhost:5984
Connection: keep-alive
Content-Length: 364
Pragma: no-cache
Cache-Control: no-cache
Origin: http://localhost:9000
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 Safari/537.36
content-type: application/json
Accept: */*
DNT: 1
Referer: http://localhost:9000/
Accept-Encoding: gzip, deflate, sdch, br
Accept-Language: en-US,en;q=0.8
Cookie: io=62j8pWngSUNyLwKjAACX; AuthSession=xyyz

{
  "_id":"org.couchdb.user:test1",
  "_rev":"1-8e2136e07f62238327f87d1ae54a29df",
  "type":"user",
  "roles":["user"],
  "name":"test1",
  "email":"test1@foo.bar",
  "fullName":"Test1 esq",
  "phone":"555-555-5555",
  "id":"org.couchdb.user:test1",
  "password_scheme":"pbkdf2",
  "iterations":10,
  "derived_key":"0e076f6f85f1389fd90ff181d433e1438e8e30a4",
  "salt":"37f590de042f07956f6cc11b8a9eb012"
}

因此,由于端口号不同,您遇到了引荐来源网址和预期主机不匹配的问题。据此https://github.com/couchbase/couchdb/blob/2.5.1.1/src/couchdb/couch_httpd.erl#L344 你可以把 X-Forwarded-Host header 放在你的值 - localhost:9000