gpt4 book ai didi

couchdb - 在 CouchDB 1.0 中创建用户时出错

转载 作者:行者123 更新时间:2023-12-04 17:41:11 26 4
gpt4 key购买 nike

我的系统是 ubuntu 10.04,我安装了 CouchDB 1.0。我可以创建管理员或更多管理员,以管理员身份登录,一切正常。

从 CouchDB 的 0.11 开始,就存在非管理员用户的概念,并且可以对数据库拥有细粒度的权限。我想创建这样的用户。我打开被褥,我没有登录,我点击“注册”链接(右下角)。然后是关于用户名和密码的问题。当我填写表格并提交时,“用户名”字段下有很长的错误消息:

注册错误:{gen_server,call, [couch_query_servers, {get_proc,{doc,<<"_design/_auth">>, {1, [<<84,165,145,147,156,145,146,42,53,239,238,7, 235,114,>>}>> , {[{<<"language">>,<<"javascript">>}, {<<"validate_doc_update">>, <<"\n function(newDoc, oldDoc, userCtx) {\n if ((oldDoc && oldDoc.type !== 'user') || newDoc.type !== 'user') {\n throw({forbidden : 'doc.type must be user'});\n }//我们只允许现在的用户文档\n\n if (newDoc._deleted === true) {\n//允许管理员和匹配用户删除\n//不检查其他字段\n if ((userCtx.roles.indexOf( '_admin') !== -1) ||\n (userCtx.name == oldDoc.name)) {\n return;\n } else {\n throw({forbidden: '只有管理员可以删除其他用户文档.'});\n }\n }\n\n if (!newDoc.name) {\n throw({forbidden: 'doc.name is required'});\n }\n\n if (! (newDoc.roles && (typeof newDoc.roles.length !== 'undefined'))) {\n throw({forbidden: 'doc.roles must be an array'});\n }\n\n if ( newDoc._id !== ('org.couchdb.user:' + newDoc.name)) {\n throw ({\n forbidden: 'Doc ID must be of the form org.couchdb.user:name'\n });\n }\n\n if (oldDoc) {//验证所有更新\n if (oldDoc. name !== newDoc.name) {\n throw({forbidden: 'Usernames can not be changed.'});\n }\n }\n\n if (newDoc.password_sha && !newDoc.salt) {\n throw({\n forbidden: '拥有 password_sha 的用户必须有盐。' +\n '参见/_utils/script/couch.js 示例代码。'\n });\n }\n\n if ( userCtx.roles.indexOf('_admin') === -1) {\n if (oldDoc) {//验证非管理员更新\n if (userCtx.name !== newDoc.name) {\n throw( {\n forbidden: '你只能更新你自己的用户文档。'\n });\n }\n//验证角色更新\n var oldRoles = oldDoc.roles.sort();\n var newRoles = newDoc .roles.sort();\n\n if (oldRoles.length !== newRoles.length) {\n throw({forbidden: 'Only _admin may edit roles'});\n }\n\n for (变量 i = 0; i < oldRoles.length; i++) {\n if (oldRoles[i] !== newRoles[i]) {\n throw({forbidden: 'Only _admin may edit roles'});\n }\n }\n } else if (newDoc .roles.length > 0) {\n throw({forbidden: 'Only admin may set roles'});\n }\n }\n\n//用户数据库中没有系统角色\n for (var i = 0; i < newDoc.roles.length; i++) {\n if (newDoc.roles[i][0] === '') {\n throw({\n forbidden:\n '没有系统角色(开始带下划线) in users db.'\n });\n }\n }\n\n//没有系统名称作为名称\n if (newDoc.name[0] === '_') {\n throw({forbidden: '用户名不能以下划线开头。'});\n }\n }\n">>}]}, [],false,[]}, {<<"_design/_auth">>, <<"1-54a591939c91922a35efee07eb2c3a72">>}}]}

它是什么?如何在 CouchDB 中创建用户?

最佳答案

要创建用户,请将 JSON 文档放入 http://localhost:5984/_users/org.couchdb.user:<username>
例如创建一个文件 login.json像这样:

{
"_id": "org.couchdb.user:test",
"name": "test",
"password_sha": "24e8e07c23d8ae85108468ec4814b2f0fa84edde",
"salt": "78f67e252351a56d6e1e6df9ba005239",
"roles": [],
"type": "user"
}

然后将数据放入 couchdb:
curl -X PUT http://<admin>:<password>@localhost:5984/_users/org.couchdb.user%3Atest -S -s -H "Content-Type: application/json" -d @login.json

(用您的 couchdb 凭据替换 <admin><password>。)

现在您应该能够使用用户“test”和密码“test123”登录到 couchdb。

关于couchdb - 在 CouchDB 1.0 中创建用户时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3456256/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com