MongoDB+php7搭建
0x00前言:
今天一位非计算机专业的朋友问我怎么打开.bson文件,我第一反应.bson文件是什么,网上查了下是mongodb的传输文件。也就是类似于mysql的.sql文件一样
之前看过mongodb的注入,但是没有亲自实践,这次一并从环境搭建开始学习了波mongodb
0x01 mongodb是什么:
mongodb和mysql等数据库管理软件作用一样,就是用来存放数据的
mongodb与mysql,mssql等数据库不同在于,它不是关系数据库,而是一种集合中包含键值对形式存放数据的管理软件
关系数据库结构一般是:库,表,字段,每一行数据是个组元
非关系数据库以这里的mongodb为例结构是:库,集合,键值对
0x02 搭建mongodb+php:
我搭建的环境是ubuntu 16.04,事先已经装好了php+apache2+mysql
那么要搭建mongodb和php之间通信,可以简单来概括为两步:安装mongodb,配置php的mongodb模块
安装mongodb
apt-get install mongodb
安装好可以直接在本地连接

这里简单说下基础操作语句
查询数据库
show dbs;

进入数据库(如果目标不存在,就是创建个新的数据库,但是要写入才能show得出来)
use sijidou; //创建库
db.createCollection('siji'); //创建集合

查看集合
show collections;

给某个集合内添加数据,插入的语句类似于json的格式
db.siji.insert({id:1,name:'sijidou',age:'18'})

查看某个集合的内容
db.siji.find()

安装php-mongodb模块
apt-get install php-mongodb
重启apache,在phpinfo中就可以看到mongodb模块的信息了(刚装好可能下面的信息不一样,但是有这一个大栏就行)

php7与php其他版本运行mongodb的方式不同,php5的格式可以参照
http://www.runoob.com/mongodb/mongodb-php.html
但是安装的步骤可能和我上面讲的不同
php7的格式为,这里以最简单的查询语句为例
<?php
$manager = new MongoDB\Driver\Manager("mongodb://localhost:27017");
//设置过滤规则,有点类似mysql的where
$filter = [];
//设置操作
$options = [];
//生成查询对象
$query = new MongoDB\Driver\Query($filter, $options);
//对相应的 sijidou库 的siji集合 进行查询
$cursor = $manager->executeQuery('sijidou.siji', $query); foreach($cursor as $result){
print_r($result);
echo "<br>";
}
?>
但是运行的时候可能会出现以下问题
php7 erver at localhost:27017 reports wire version 2, but this version of libmongoc requires at least 3 (MongoDB 3.0)
这个原因是mongodb的版本是2,但是php要求至少要3以上的
遇到这个问题升级mongodb数据库,步骤如下
导入包管理系统所需要的key
sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv EA312927
为mongodb创建个apt-get的列表
echo "deb http://repo.mongodb.org/apt/ubuntu xenial/mongodb-org/3.2 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-3.2.list
更新本地包
sudo apt-get update
升级安装
sudo apt-get install -y mongodb-org
但是在这种情况下又会遇到,服务启动不了的情况
Failed to start mongodb.service: Unit mongodb.service is masked.
依次执行以下步骤
sudo rm /var/lib/mongodb/mongod.lock
sudo mongod --repair --dbpath /var/lib/mongodb
sudo mongod --fork --logpath /var/lib/mongodb/mongodb.log --dbpath /var/lib/mongodb
sudo service mongodb start
环境差不多就搭建完成了,接下来添加几组数据并测试一下

如果要导入.bson文件的话
mongorestore -d 库名 文件路径
mongorestore -d csh ./articles.bson
0x03 MongoDB注入?
首先修改下源码,并模拟添加个flag集合

<?php
$name = $_GET['name'];
$manager = new MongoDB\Driver\Manager("mongodb://localhost:27017"); $filter = ['name' => $name];
$options = []; $query = new MongoDB\Driver\Query($filter, $options);
$result = $manager->executeQuery('sijidou.siji' ,$query); foreach($result as $ans){
print_r($ans);
} ?>
这里的filter的内容表示 name =$name的值,效果如下

然后我们可以用name[$ne]=sijidou显示不是sijidou的值

其他的方法:
$gt -- '>'
$lt -- '<'
$ne -- '!='
$eq -- '='
$gte -- '>='
$lte -- '<='
但是看了网上的mongodb注入方式,发现没有php7的,都是php5
php5的查询语句可以是这样的
$query = "var data = db.sijidou.findOne({name:'$username'});return data;";
//调用
$mongo = new mongoclient();
$db = $mongo->sijidou;
$data = $db->execute($query);
$query的内容是整个js代码字符串,那么就可以操作了
比如 username的内容为
sijidou'}); return version();var data2 = db.sijidou.findOne({name:'sijidou
拼接后,执行了3条语句,其中version()就是目标值
var data = db.sijidou.findOne({name:'sijidou'}); return version();var data2 = db.sijidou.findOne({name:'sijidou'});return data;
防御方法:addslashes()转义
但是但是但是!!!
这个在php5中查询MongoDB和mysql一样是整句语句,而php7是用filter和options,所以没法这么注入,我也没找到啥好的方法
至于php7中的,name[$ne]=sijidou,这种返回其他的值的情况,可以使用下面方法避免

name[$ne]=sijidou,不会返回结果了

因此这个小测试也拿不到flag
0xFF 结语
总得来说,php7比php5使用MongoDB更加麻烦一点,但是更加安全
参考链接
https://blog.csdn.net/jws2011520/article/details/78157778
https://www.cnblogs.com/mrchang/p/6255226.html
https://cl0und.github.io/2018/01/12/MONGODB%E6%B3%A8%E5%85%A5%E5%AD%A6%E4%B9%A0/
MongoDB+php7搭建的更多相关文章
- Mongodb - 切片搭建
0.概述 mongodb分片搭建,版本号4.0.2,以下除了创建opt文件夹以外,所有操作均在mongodb用户下面执行 准备三台机器:192.168.56.81192.168.56.82192.16 ...
- 《OD大数据实战》MongoDB环境搭建
一.MongonDB环境搭建 1. 下载 https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.0.6.tgz 2. 解压 tar -zxvf ...
- 【MongoDB】MongoDB服务器搭建(Unix/Linux)
1.安装MongboDB安装包(开源免费的哟) 在Mac 下 brew install mongoDB 就可以啦 安装要等一会儿,大概200M 2. cd到MongboDB文件夹 - 如果是用home ...
- MongoDB——环境搭建
项目中需要将一些读多改少的数据存入到 MongoDB 数据库中来提高效率,于是简单学习一些MongoDB数据库的知识,来进行应对,也是对自己知识盲区进行补充.本文主要学习介绍MongoDB数据库在Li ...
- MongoDB:搭建三节点 Replica Set 环境
今天学习了搭建 MongDB 复制环境,实验环境是在虚拟机上同一系统,并搭建三节点 Replica Set,根据文档上的描述,mongodb 复制配置简单,并且能够自动 failover,这些高级特性 ...
- mongodb主从搭建
#tigergao 官网进行下包,可以下载源码包或者二进制包,本次下载的为二进制包,进行试验. 主服务器搭建: mkdir mongomaster cp mongodb-linux-x86_64-rh ...
- MongoDB环境搭建
MongoDB系列第一课:MongDB简介 MongoDB系列第二课:MongDB环境搭建 MongoDB系列第三课:MongDB用户管理 MongoDB系列第四课:MongoDB数据库.集合.文档的 ...
- NoSql数据库初探-mongoDB环境搭建
NoSQL数据库一改关系型数据库的缺点,更容易的集成.分布式.无模式.故障恢复等特点,正在一步步餐食关系型数据库的市场,作为一个与时俱进的码农了解一下新技术是必须的,尤其是在读了<NoSql精粹 ...
- Windows下MongoDB环境搭建
MongoDB下载 登录MongoDB官网:www.mongodb.org:点击[Download MongoDB]按钮,进入如下所示界面 选择目标操作系统及其版本,比如这里选择的是64位的Windo ...
随机推荐
- 按照勾选 删除表格的行<tr>
需求描述:有一个产品列表,有一个删减按钮,点击删减按钮,按照产品勾选的行,删除产品列表中对应的行数据 代码: //html代码<table id="table1"> & ...
- Python基础之继承与派生
一.什么是继承: 继承是一种创建新的类的方式,新建的类可以继承一个或过个父类,原始类成为基类或超类,新建的类则称为派生类 或子类. 其中,继承又分为:单继承和多继承. class parent_cla ...
- bzoj 2190
题意:求 题解:这题...数据范围是真小... 研究一下这一表达式,发现gcd(i,j)=1表示i,j互质,那么互质肯定能想到欧拉函数,可是欧拉函数要求j<i,那么我们变化一下:显然原矩阵是对称 ...
- Jmeter中通过beanshell写入CSV的脚本
import com.csvreader.CsvWriter; String NewDataPath=bsh.args[0]; NewDataPath=NewDataPath.replaceAll(& ...
- JS判断元素 动画是否执行完成
使用animationend方法 var ele = document.getElementById("box"); ele.addEventListener("anim ...
- 步步为营-104-Lambda语句
1:Lambda的拼接 首先借助一个Lambda的帮助类 using System; using System.Collections.Generic; using System.Linq; usin ...
- expect 安装 salt 客户端
#!/bin/bash for i in $(cat ./host.txt) do echo $i > ./tmp.txt HOSTNAME=$(cut -d ':' -f1 ./tmp.txt ...
- 下载中间件--随机IP代理以及随机User_Agent
下载中间件随机IP代理以及随机User_Agent 1.在settings.py中设置开启代理功能 # 设置下载中间件 DOWNLOADER_MIDDLEWARES = { # 随机的 User-Ag ...
- .NET成年了,然后呢?
作者|Lex Li 编辑|郭蕾 这可能是唯一一篇系统回顾 .NET 发展的文章..NET 的成年礼到了,你会送它什么? 2014 年 11 月 12 日,美国纽约曼哈顿,多云,气温适宜.微软公司执行副 ...
- 3897: Power
题解: 首先很贪心的选择 有最大的我们一定会用最大的 然后可以将序列分割.. 就变成了一道模拟题了.. 每个状态记录(h,t,h-have,t-need) 注意一下细节就可以了 代码: #includ ...