首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MongoDB授权访问漏洞复现

人不狠,话不多的表弟登场 0x00简介 MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。...MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。...0x02漏洞成因 在刚安装完毕的时候MongoDB都默认有一个admin数据库,此时admin数据库是空的,没有记录权限相关的信息!...随缘选一个ip然后祭出神奇metasploit MongoDB默认端口27017,当配置成无验证时,存在授权访问,使用msf中的scanner/mongodb/mongodb_login模块进行测试,...use auxiliary/scanner/mongodb/mongodb_login set rhosts 192.168.90.0/24 set threads 10 exploit ?

3.6K20
您找到你想要的搜索结果了吗?
是的
没有找到

MongoDB 授权访问漏洞修复方案

尊敬的腾讯云客户: 您好,近日,腾讯云安全中心情报侧监控显示,目前云上部分用户MongoDB服务器仍然存在的授权安全漏洞,黑客可利用此类漏洞发起新一轮勒索攻击,会导致您的服务器中的数据被擦除,并被索要赎金...【风险描述】: 开启MongoDB服务时不添加任何参数时,默认是没有权限验证的,登录的用户可以通过默认端口无需密码对数据库任意操作而且可以远程访问数据库。 2....打开MongoDB配置文件(.conf),设置为auth=true; 2、修改访问端口和指定访问ip。...使其只监听私有IP(或本地IP),不监听任何公网IP或DNS; 官方方案:具体可参考:https://docs.mongodb.com/manual/security/ 。

1.7K41

MongoDB(11)- 查询数组

, { item: "postcard", qty: 45, tags: ["blue"], dim_cm: [ 10, 15.25 ] } ]); 后面的栗子都会用到这里的测试数据 精确匹配数组...语法格式 { : { : , ... } } { 数组字段名 : { 操作符:值, 操作符2: 值2, ..... }} 实际栗子 查询数组...在数组元素上指定复合条件时,可以指定查询使得单个数组元素满足这些条件或数组元素的任意组合满足条件 在数组元素上使用复合条件 > db.inventory.find( { dim_cm: { $gt:...使用 $elemMatch 运算符在数组元素上指定多个条件,使得至少一个数组元素满足所有指定条件 小栗子 查询 dim_cm 数组包含至少一个大于 (gt) 22 且小于 (lt) 30 的元素的文档...60b5fb209ba88b2120d5de26"), "item" : "planner", "qty" : 75, "tags" : [ "blank", "red" ], "dim_cm" : [ 22.85, 30 ] } 按数组长度查询数组

2.3K10

MongoDB操作&&注入漏洞&&授权访问漏洞

注入不止有传统的SQL数据库,NoSQL型数据库也一样存在注入漏洞,在比赛中跟传统的注入相比也算新题型,不少同学可能还不太了解,本文向大家科普MongoDB数据库的常见操作以及攻击的方法——NoSQL注入和授权访问...,因为 JavaScript的数组增删元素就是用 push& pop $each,批量修改数组 db.collection.update({}, {"$update": {key: {"$each":...注入的闭合、注入,相信大家都比我懂,就不献丑了) ---- 授权访问 MongoDB最初安装部署后是不会添加auth选项的,一般的初始化步骤是: 不开启auth选项时连接数据库,添加管理员账户 开启auth...,利用管理员账号登录连接,添加数据库账户 但是很多开发者并不知道这些Tips,没有开启auth选项,且数据库监听了公网,就导致了MongoDB授权访问 其实MongoDB授权访问和Redis数据库是差不多的...我将数据库不开启auth启动,然后NoSQLMap的1选项设置想关信息 接着点击2选项,提示存在授权访问漏洞 ? 点击枚举数据库信息 ?

4.1K30

MongoDB 数组mongodb 中存在的意义

在MOGNODB 的文档设计和存储中,存在两个部分 1 嵌套 2 数组,所以如果想设计好一个MONGODB 在理解业务,读写比例,查询方式后,就需要介入到更深层次的理解嵌套的查询方式,嵌套多层后的性能问题...MONGODB 中的数组是属于同类型数据的元素集合,每个数组中的元素代表这个数组中同样属性的不同值,其实我们可以理解为,在一个JSON 中,有行和行列集合的存在,本身JSON可以通过数组的方式,在一个平面里面表达一个列的集合...匹配所有的score中数组的元素,并进行count ,然后进行聚合操作,并通过project进行投射的工作,最终显示出下图的内容,每行score的元素个数。...({system_name:"oracle"},{$set:{"score.4":50}}) 另外对于数组的另外一个功能,就是将一些设计中的行转换在MONGODB数组方式,类似于行转列的方式设计...数组MONGODB 中存在的意义很大,在很多设计中都可以通过数组的使用降低查询的复杂度和降低建立索引的SIZE。

4.2K20

MongoDB 数组元素增删改

与关系型数据库相比,MongoDB支持数组,将数组存储到文档之中。因此,与之对应的是数组的增删改查。对于有C语言基础的童鞋,数组应该不会陌生。数组的增删改查,在MongoDB中有相应的操作符来实现。...有关数组的查询可以参考:MongoDB 数组查询 1、占位符$ 占位符$的作用主要是用于返回数组中第一个匹配的数组元素值(子集),重点是第一个 在更新时显示指定数组中元素位置的情形下,占位符$用于识别元素的位置...,也即是只有第一个为90的值才会被显示,其余的元素值不被显示 > db.students.find( { semester: 1, grades: { $eq: 90 } },{ "grades....$": 1 } ) { "_id" : 1, "grades" : [ 90 ] } { "_id" : 2, "grades" : [ 90 ] } //注意这里显示的是该文档的第一个...100, 90 ] } //下面使用multi:true选项,如下可知,2个匹配文档被更新 //但是仅仅是第一个元素值被更新(文档_id为2数值值为90的第二个元素更新

6.6K40

Mongodb多键索引之数组

【背景】 最近有项目需求用到多键索引,Mongodb中字段值支持多键索引主要包括嵌套文档、数组以及数组嵌套文档.例如联系包括手机、固定电话、邮箱、微信、QQ等,对于字段值存储类型不一样,决定创建多键索引也不一样同时性能也存在差异...,例如数组值(包括数组以及数组文档),创建多键索引时会为数组中每个元素都创建索引键,如数组中元素特别多,相应索引也会特别大,创建多键索引或者组合索引时最多只支持一个数组值....] 数组文档:“联系”:[“telephone”:{"cellphone":"0211234567","mobilephone":13888888888}] 【数组值创建并高效使用索引】 1、集合中文档信息...} xiaoxu:PRIMARY> 2、创建多键索引 db.survey.createIndex({"ratings":1},{background:1}); 备注:创建多键索引不需要显示关键字...逻辑: 1、数组索引位置从0开始,当对数组创建索引时,使用索引位置查询时,是无法使用多键索引,必须创建单独索引,例如第二个元素位置, db.survey.createIndex({

1.7K30

SystemVerilog(九)-网络和变量的压缩数组

非压缩数组是网络或变量的集合。 集合中的每个网络或变量称为数组元素。压缩数组的每个元素的类型、数据类型和向量大小都完全相同。每个压缩的数组元素可以独立于其他元素存储;这些元素不需要连续存储。...软件工具,如仿真器和综合编译器,可以以工具认为最佳的任何形式组织压缩数组的存储。 压缩数组的基本声明语法为: 数组的维度定义了数组可以存储的元素总数。...压缩的数组可以用任意数量的维度声明,每个维度存储指定数量的元素。声明数组维度有两种编码样式:显式地址和数组大小。...复制数组(阵列) 如果两个数组(阵列)具有相同的布局,则可以使用赋值语句将一个压缩的数组(阵列)复制到另一个压缩的数组(阵列)。...数组列表赋值 可以为压缩的数组数组的一个片段分配一个值列表,这些值包含在每个数组维度的’{and}大括号之间。

2.1K30

MongoDB查询(数组、内嵌文档和$where)

【查询数组】 查询数组很容易,对于数组,我们可以这样理解:数组中每一个元素都是这个键值对键的一个有效值,如下面的例子:我们要查询出售apple的水果店: ? 我们发现只要包含苹果的数组都能被查询出来。...我们看,使用“$all”对数组内元素的顺序没有要求,只要全部包含的数组都能查询出来。数组查询也可以使用精确匹配的方式,即查询条件文档中键值对的值也是数组,如: ?...如果是精确匹配的方式,MongoDB的处理方式是完全相同的匹配,即顺序与数量都要一致,上述中第一条文档和查询条件的顺序不一致,第三条文档比查询条件文档多一个元素,都没有被匹配成功!...但如果实际中真的遇到一种情况无法用上述方式实现时,不用慌,MongoDB为我们提供了终极武器:"$where",用他可以执行任意JavaScript作为查询的一部分!...我们可以看出,使用"$where"其实就是写了一个javascript函数,MongoDB在查询时,会将每个文档转换成一个javascript对象,然后扔到这个函数中去执行,通过返回结果来判断其是否匹配

6K20

使用insert () 在MongoDB中插入数组

我们完成如下步骤即可: 1)创建一个名为myEmployee 的JavaScript变量来保存文档数组; 2)将具有字段名称和值的所需文档添加到变量; 3)使用insert命令将文档数组插入集合中...Employeeid" : 3, "EmployeeName" : "Joe" }, ]; db.Employee.insert(myEmployee); 如果命令执行成功,将显示如下结果...结果显示这3个文档已添加到集合中。 以JSON格式打印 JSON是一种称为JavaScript Object Notation的格式,是一种规律存储信息,易于阅读的格式。...这将导致集合中的每个文档以JSON格式显示。 命令执行成功,显示以下输出内容: 结果: ? 表明所有文档都是以JSON样式输出打印的。 译者:徐杨 MongoDB中文社区翻译志愿者,资深程序员。

7.6K20

MongoDB(12)- 查询嵌入文档的数组

查询 instock 数组中包含 { warehouse: "A", qty: 5 } 的所有文档 > db.inventory.find( { "instock": { warehouse: "...精确匹配整个文档数组的栗子 > db.inventory.find({instock: [ { warehouse: "A", qty: 60 }, { warehouse: "B", qty: 15...在 instock 数组中,至少有一个文档的 qty 字段值是 ≤20 的 > db.inventory.find( { 'instock.qty': { $lte: 20 } } ) { "_id"...,如果不知道文档的准确索引值,只能按照以下格式 数组字段名.文档字段名 instock.qty 使用数组索引查询嵌入文档中的字段 上面的栗子是直接根据字段名查找 在 instock 数组中,第一个元素包含字段...(前面讲数组的时候也提到过) 栗子一 找到在 instock 数组【至少有一个包含 qty = 5 和 warehouse = A 的嵌入文档 】的文档 > db.inventory.find( { "

4.6K10

MongoDB开发系列-数组的应用实践

本文讨论MongoDB数组使用的相关注意事项,默认读者对MongoDB数组的概念和使用场景有一定了解。...文章中将涉及到以下内容 01 数组的使用场景 0101 1:N的包含结构使用数组 0102 单文档大小限制 02 多种数组操作方式 0201 使用$push 追加数组元素...0202 使用$unwind聚合分离数组元素 数组MongoDB中最能体现MongoDB嵌套设计思想的数据结构。...从一张MongoDb社区活动的PPT谈起,什么场景下适合使用数组? ?...可控的文章评论列表,或者是工单更新回复日志都可以使用数组来保存。 多种数组操作方式 在MongoDb中操作数组不是像关系型数据库那么工整方便,但是不用担心,是有方法可操作的。

1.1K40

Mongodb 数组使用的注意事项

mongodb中包含数组数组MONGODB 的使用中是一个比较方便的存在,如我们去处理处理一个数组的事例 db.articles.insert([ { "_id" : 1, "description...,并在数组中有多个元素,在MONGODB 4.x 之后针对数组的查询,产出了$elemMatch的查询的方式,具体查询的方式为 fieldName: { $elemMatch: {条件,条件}} 在不添加索引的情况下...1 数组内的元素添加后,会造成整体基于数组的索引进行物理的数据的重排,造成数组在磁盘上的数据进行重组,导致I/O消耗。如果数组中的元素过多,甚至会产生重建索引的效果。...这里不光是数组元素的添加,数组元素的消减也是会产生类似的效果。...,并没有使用MONGODB4.0及以上的版本,这关于数组元素的查询都是一个灾难,在一定数据量级的情况下,产生数据查询的性能问题。

73310
领券