用户无法通过 _session 的身份验证

Users can't be authenticated for _session

我面临一个非常奇怪的问题,我无法使用 (_users) 数据库中的任何用户通过路由 (/_session) 创建会话。它总是给我错误(凭据错误)。它曾经在 couchdb 1.6.1

中运行良好

对于普通的 couchdb 管理员,它工作正常:

$ curl -X POST http://localhost:5984/_session -d 'name=my_main_admin&password=******'
{"ok":true,"name":"my_main_admin","roles":["_admin"]}

但是对于 couchdb 用户(存储在 _users 中),它不起作用。我不认为这是关于角色的。

所以我首先创建用户:

$ curl -s -H "Content-Type: application/json" -X PUT "http://my_main_admin:*****@127.0.0.1:5984/_node/_local/_users/org.couchdb.user:my_new_user" --data '{"name": "my_new_user", "password": "my_new_user", "roles": [], "type": "user"}'
{"ok":true,"id":"org.couchdb.user:my_new_user","rev":"1-f1fa0870666d17d7324e54128dfbcacb"}

然后如果我尝试使用此用户创建会话,它永远不会工作:

$ curl -X POST http://localhost:5984/_session -d 'name=my_new_user&password=my_new_user' {"error":"unauthorized","reason":"Name or password is incorrect."}

我的 CouchDB 配置看起来不错:

"couch_httpd_auth": {
"allow_persistent_cookies": "true",
"auth_cache_size": "50",
"authentication_db": "_users",
"authentication_redirect": "/_utils/session.html",
"iterations": "10",
"require_valid_user": "false"

我曾经在 couchdb 1.6.1 上与普通用户创建会话,但是自从我安装了 couchdb 3.1.1 之后它就再也没有用过。我在文档中找不到任何相关信息。 我错过了什么吗?

问题是您正在通过 _node/_local 接口创建用户。用户应该通过 _users 集群数据库上的集群 API 创建。

    $ curl -s -H "Content-Type: application/json" -X PUT \
  "http://my_main_admin:*****@127.0.0.1:5984/_users/org.couchdb.user:my_new_user" \
 --data '{"name": "my_new_user", "password": "my_new_user", "roles": [], "type": "user"}' \
    /

现在您应该能够使用 _session 端点以新用户身份登录。