Django SQL注入漏洞(CVE-2020-7471)复现

Django SQL注入漏洞(CVE-2020-7471)复现

漏洞简介:

 Django官方发布安全通告公布了一个通过StringAgg(分隔符)实现利用的潜在SQL注入漏洞(CVE-2020-7471)。攻击者可通过构造分隔符传递给聚合函数contrib.postgres.aggregates.StringAgg,从而绕过转义并注入恶意SQL语句。

影响版本:

  1. Django 1.11.x < 1.11.28

  2. Django 2.2.x < 2.2.10

  3. Django 3.0.x < 3.0.3

  4. Django 主开发分支

环境搭建:

安装Django(v3.0.2)

pip3 install django==3.0.2 -i https://pypi.tuna.tsinghua.edu.cn/simple

 

安装postgres

apt-get install postgresql-11

开启服务并登录账号postgres

密码为空

给数据库超级用户postgres添加密码123456

然后创建数据库

 

Poc地址: https://github.com/Saferman/CVE-2020-7471.git

修改 sqlvul_projects/settings.py

修改相关配置信息,我这里修改了密码其他一样即可

接下来就是利用manage.py进行初始化和配置了

初始化数据表(django)

python3 manage.py migrate

python3 manage.py makemigrations vul_app

python3 manage.py migrate vul_app

依次执行命令查看vul_app_info里是否有内容

sudo -i -u postgres

psql

\c test

\d

select * from vul_app_info;

没有 

 

漏洞复现:

运行 POC 脚本(CVE-2020-7471.py)查看结果

 

回到数据库中,发现存在内容了,成功

漏洞修复:

升级到最新版。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值