(4)BUUCTF-web-[极客大挑战 2019]EasySQL1

前言:

觉得这个题目挺有意义的,因为最近在学数据库,但是不知道在现实中有什么应用,所以学起来也没有什么兴趣,做了这个题目,发现数据库还是挺有用处的,哈哈

知识点:

mysql 中and和or的优先级

()> and > or

sql="select * from DB where user_id=1 or user_name='张三' and birthday='2000-03-03'"

1.该条sql 表示从 DB 中查询出 user_id =1 或者 (user_name='张三' 并且 birthday='2000-03-03') 的数据

sql="select * from DB where (user_id=1 or user_name='张三') and birthday='2000-03-03'"

2.该条sql 表示查询表示(user_id =1 或者 user_name='张三')并且 birthday='2000-03-03')

因为 () 的优先级会比 and 和 or 高 所以会先执行 ()里的

解题过程:

打开靶机后发现是一个登录界面,需要输入用户名和密码

先看看只输入用户民admin看看有什么报错

然后只输入密码也是同样的报错,所以用户名和密码都必须有值才能进行sql语句验证

判断是什么闭合

输入用户名admin'和admin

发现一个sql报错信息, 得知是''闭合

猜测后台的sql语句如下:

sql="select * from user where username='username\&'and password='password&'"

然后使用万能密码看看能不能登录admin账户

payload:

用户名:admin

密码:admin' or 1=1#

然后就出flag了

万能密码的原理是利用or和and的优先级来使得后面的where子句为真

我们输入的payload放入sql语句中就是这样的:

sql="select * from user where username='admin'and password='admin' or 1=1#'"

意思是:查询(用户名为admin并且password=admin)或者1=1的数据 #把后面的给注释掉了

因为1=1恒真,所以where子句后面恒真,所以就会输出所有用户的信息。

如果想只输出admin的信息可以使用:

payload:

用户名:admin ' or 1=1#

密码:admin

输入的payload放入sql语句中就是这样的:

sql="select * from user where username='admin' or 1=1#'and password='admin'"

意思是:查询username=admin或者1=1,#把后面注释掉了,所以不用管。

这样就只会输出admin的信息。

相关推荐
草莓熊Lotso16 分钟前
MySQL 索引特性与性能优化全解
android·运维·数据库·c++·mysql·性能优化
Kapaseker17 分钟前
千万不要以为你搞懂了 var 和 val
android·kotlin
TE-茶叶蛋27 分钟前
安卓应用(uniapp开发)分享微信-申请appid
android·微信·uni-app
大白要努力!33 分钟前
Android libVLC 3.5.1 实现 RTSP 视频播放完整方案
android·java·音视频
AirDroid_cn44 分钟前
手机上看的网页,怎样自动在荣耀 MagicOS 10 平板上接着打开?
android·智能手机·电脑·荣耀手机
帅次1 小时前
WebView 并发初始化竞争风险分析
android·xml·flutter·kotlin·webview·androidx·dalvik
spencer_tseng1 小时前
HTML5 - Android - IOS
android·ios·html·html5
游戏开发爱好者81 小时前
iOS 开发进阶,用 SniffMaster 实现 iPhone 抓包深度分析
android·ios·小程序·https·uni-app·iphone·webview
华科易迅9 小时前
MybatisPlus增删改查操作
android·java·数据库
SHoM SSER10 小时前
MySQL 数据库连接池爆满问题排查与解决
android·数据库·mysql