学堂 学堂 学堂公众号手机端

如何解决Mongodb3.2.9开启用户权限认证问题

lewis 1年前 (2024-03-24) 阅读数 5 #技术

这篇文章给大家分享的是有关如何解决Mongodb 3.2.9开启用户权限认证问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

一、在老版的Mongodb(大概3.0以前)可以这样开启认证:

1、Linux环境下mongo shell方式认证:


>showdbs
##看到有如下数据
admin(empty)
comment0.203125GB
dbtest(empty)
foo0.203125GB
local(empty)
test0.203125GB
>useadmin
switchedtodbadmin
>db.addUser('admin','12345678')##添加用户
MonNov523:40:00[FileAllocator]allocatingnewdatafile/data/db/admin.ns,fillingwithzeroes...
{
"user":"admin",
"readOnly":false,
"pwd":"89e41c6c28d88d42c21fe501d82969ea",
"_id":ObjectId("5097ddd00342c63efff3fbfb")
}
##之后运行
>showdbs
MonNov523:45:13uncaughtexception:listDatabasesfailed:{"errmsg":"needtologin","ok":0}##提示需要登录

添加--auth启动
./mongod-auth
./mongo

>useadmin
switchedtodbadmin
>db.auth('admin','12345678')##用添加的账户密码查看
MonNov523:49:32[conn56]authenticatedb:admin{authenticate:1,nonce:"304f5242601fafa4",user:"admin",key:"58260df384b1146466efca5c90a5ff05"}
1
#1说明登录成功
>showdbs
admin0.203125GB
comment0.203125GB
dbtest(empty)
foo0.203125GB
local(empty)
test0.203125GB
>useadmin
switchedtodbadmin
>showcollections;
system.indexes
system.users
>db.system.users.find()##查找数据
{"_id":ObjectId("5097ddd00342c63efff3fbfb"),"user":"admin","readOnly":false,"pwd":"89e41c6c28d88d42c21fe501d82969ea"}

2、php代码连接认证:

<?php
##1使用超级用户连接mongodb
/*mongodb连接*/
$m=newMongo("mongodb://admin:12345678@192.168.138.35:27017");
/*选择melon数据库*/
$db=$m->melon;
/*集合*/
$collection=melonco;
/*选择数据库里面的集合,相当于表*/
$collection=$db->$collection;
$array=array('name'=>'melon','age'=>'24','sex'=>'Male','birth'=>array('year'=>'1988','month'=>'07','day'=>'13'));
$collection->insert($array);
$cursor=$collection->find();
foreach($cursoras$id=>$value){
echo"$id:";var_dump($value);echo"<br>";
}


###2使用数据库用户
/*mongodb连接*/
$m=newMongo("192.168.138.35:27017");
/*选择comment*/
$db=$m->melon;
/*连接数据库*/
$db->authenticate("melon","melon");
/*选择t数据库里面集合,相当于表*/
$collection=$db->melonco;
$array=array('name'=>'melon_son','age'=>'0','sex'=>'Male','birth'=>array('year'=>'201X','month'=>'07','day'=>'13'));
$collection->insert($array);
$cursor=$collection->find();

foreach($cursoras$id=>$value){
echo"$id:";var_dump($value);echo"<br>";
}

二、在3.0版之后的Mongodb,shell中依旧可以使用上述方法验证,但是php认证一直失败,日志中会报错( Failed to authenticate myuser@userdb with mechanism MONGODB-CR: AuthenticationFailed MONGODB-CR credentials missing in the user document),原来新版的mongodb加入了SCRAM-SHA-1校验方式,需要第三方工具配合进行验证。

下面给出具体解决办法:

首先关闭认证,修改system.version文档里面的authSchema版本为3,初始安装时候应该是5,命令行如下:

>useadmin
switchedtodbadmin
>varschema=db.system.version.findOne({"_id":"authSchema"})
>schema.currentVersion=3
3
>db.system.version.save(schema)
WriteResult({"nMatched":1,"nUpserted":0,"nModified":1})

不过如果你现在开启认证,仍然会提示AuthenticationFailed MONGODB-CR credentials missing in the user document

原因是原来创建的用户已经使用了SCRAM-SHA-1认证方式

>useadmin
>db.auth('root','123456')
>db.system.users.find()
{"_id":"admin.root","user":"root","db":"admin","credentials":{"SCRAM-SHA-1":{"iterationCount":10000,"salt":"XoI5LXvuqvxhlmuY6qkJIw==","storedKey":"VAT7ZVMw2kFDepQQ6/E0ZGA5UgM=","serverKey":"TebHOXdmY6IHzEE1rW1Onwowuy8="}},"roles":[{"role":"userAdminAnyDatabase","db":"admin"}]}
{"_id":"mydb.test","user":"test","db":"mydb","credentials":{"MONGODB-CR":"c8ef9e7ab00406e84cfa807ec082f59e"},"roles":[{"role":"readWrite","db":"mydb"}]}

解决方式就是删除刚刚创建的用户,重新重建即可:

>db.system.users.remove({user:"test"});
>usemydb
>db.createUser({user:'test',pwd:'123456',roles:[{role:'readWrite',db:'mydb'}]})

然后开启认证,重启服务器,用php连接,一切OK

<?php
#1使用数据库用户认证连接mongodb
/*mongodb连接*/
$m=newMongo("mongodb://test:12345678@localhost:27017/mydb");
/*选择melon数据库*/
$db=$m->mydb;
/*选择数据库里面的集合stu,相当于表*/
$collection=$db->stu;
$array=array('name'=>'melon','age'=>'24','sex'=>'Male','birth'=>array('year'=>'1988','month'=>'07','day'=>'13'));
$collection->insert($array);
$cursor=$collection->find();
foreach($cursoras$id=>$value){
echo"$id:";var_dump($value);echo"<br>";
}

感谢各位的阅读!关于“如何解决Mongodb 3.2.9开启用户权限认证问题”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

版权声明

本文仅代表作者观点,不代表博信信息网立场。

热门