mongodb管理工具 rockmongo使用时出现的问题
1、一般来说,使用mongodb都会设个用户名和密码,这就要求在使用的时候需要验证。所以在config.php下的这两个参数,第一个参数就需要设置为true,开启登录验证,用户名和密码根据mongodb所设的。
$MONGO["servers"][$i]["mongo_auth"] = true;
2、如果将以下两个参数都设置为false,可以根据所输帐号登录。当然,这是在初始安装mongodb,还未设置用户名和密码的情况下可用。
$MONGO["servers"][$i]["mongo_auth"] = true;//enable mongo authentication?
$MONGO["servers"][$i]["control_auth"] = true;//enable control users, works only if mongo_auth=false
3、如果设置了用户名和密码。那么,登录时就需要验证,而很多情况下,会发现,验证不通过。
报的信息如下:
MongoDB authenticate failed. Please check your username and password from your mongo administrator.
究其原因,如下:
mongodb的PHP扩展版本分为PHP vc6版和VC9版,我到官网下到的VC6版的,DLL文件最新的是1.2版本的,而VC9的 1.4.5。而大于1.3版本的DLL文件支持一个叫MongoClient的类,而这个类的前身版本是Mongo。在Mongo下有些方法的使用被受到了限制,比如
MongoDB::execute,MongoDB::authenticate,MongoDB::command
这些方法,在很多情况下执行脚本的时候,被要求做登录验证,而直接使用
$db->authenticate ($username,$password);
等往往会出现验证失败
因为这里要求,开始的时候不要设置链接,使用如下:
//$dsn="localhost:27017"; //如果加了这句在下面的new Mongo()里同样会验证不通过,这样就发现在,只能在本机使用
$m = new Mongo();
$db = new MongoDB($m, 'memo');
$res = $db->authenticate("root", "123456");
4、rockmongo修改如下:
config.php
$MONGO["servers"][$i]["mongo_auth"] = true;//enable mongo authentication?
$MONGO["servers"][$i]["control_auth"] = true;//enable control users, works only if mongo_auth=false
static function listCollections(MongoDB $db) {
$server = MServer::currentServer();
$names = array();
try {
// $names = self::exec($db, 'function (){ return db.getCollectionNames(); }');//fzy.modify
$names=$db->listCollections();
return $names;
} catch(Exception $e) {
}
RMongo.php
public function __construct($server, array $options = array()) {
if (class_exists("MongoClient")) {
$this->_mongo = new MongoClient($server, $options);
}
else {
// $this->_mongo = new Mongo($server, $options); //版本初始代码
/*==================修改为以下代码=====================*/
$dns = "mongodb://".$options["username"].":".$options['password']."@".$server."/".$options["db"];
$this->_mongo = new Mongo($dns);
}
}
MServer.php
auth方法下
if ($this->_mongoAuth) {
// "authenticate" can only be used between 1.0.1 - 1.2.11
if (RMongo::compareVersion("1.0.1") >= 0 && RMongo::compareVersion("1.2.11") < 0) {
$dbs = $db;
if (!is_array($dbs)) {
$dbs = preg_split("/\\s*,\\s*/", $dbs);
}
foreach ($dbs as $db) {
// $ret = $this->_mongo->selectDb($db)->authenticate($username, $password); //修改前代码
//-----------------------修改后代码------------------------------------
$salted = "${username}:mongo:${password}";
$hash = md5($salted);
$nonce = $this->_mongo->selectDb($db)->command(array("getnonce" => 1));
$saltedHash = md5($nonce["nonce"]."${username}${hash}");
$ret = $this->_mongo->selectDb($db)->command(array("authenticate" => 1,
"user" => $username,
"nonce" => $nonce["nonce"],
"key" => $saltedHash
));
//-----------------------------------------------------------
if (!$ret["ok"]) {
return false;
}
}
经过上面的修改,管理帐号和普通帐号应该可以正常登录了。不过,出现了一个问题,还没排查。
普通帐号登录后,使用查询功能,会现错,原因可能是不能正确解析或执行JSON格式的脚本(如前面所说),而数组查询是可用的。当然,所有点击性操作是正常的。
管理帐号登录后,操作上没遇到什么问题。