Less-20
今天的靶场是Less-20,这关涉及cookie,要深入理解的话我们就一行行分析源代码
data:image/s3,"s3://crabby-images/6f0e3/6f0e3b796ba7a77dff672dbaaddd3b997bcacc3c" alt=""
首先,来到程序的第一个分支点,$_COOKIE这个变量是能获取到报文头部所包含的cookie字段其中的信息,我们可以分析出如果要执行这个if语句,则cookie的’uname’字段中是没有信息的。
data:image/s3,"s3://crabby-images/7f012/7f0123d0a85ae4814b9e33a5cba255dbe193d91b" alt=""
那么网页首先显示的是跟前几个关卡相似的登录页面。
接下来来到第一个分支点里的又一个分支点
data:image/s3,"s3://crabby-images/5e96d/5e96d021d26748d5c34ede170ea57465836dfe09" alt=""
可以看出当我们在网页中的表单中提交用户名和账号信息时,则开始执行这个if语句
data:image/s3,"s3://crabby-images/74e51/74e51b815ddb58437220f67ad02774c88ed8a54e" alt=""
就开始查询数据库里的用户名和密码信息
data:image/s3,"s3://crabby-images/07937/0793724385f3b5b26f8b9a891a5faec6e1eaa121" alt=""
并且将查询结果的’username’字段中的用户名信息赋值给$cookee
data:image/s3,"s3://crabby-images/3d0ae/3d0ae9064e739bcd7c1a8f46812232a86911b30d" alt=""
如果查询结果不为空
data:image/s3,"s3://crabby-images/c27c1/c27c17d4a0a5544c24e9ce746ea0940fdc806081" alt=""
则设置将cookie中设置名为’uname’的字段,并给该字段赋值$cookee变量的值,也就是之前查询到的用户名信息,并且设置该字段的生存时间
如果查询结果为空,则返回一个查询失败的信息
data:image/s3,"s3://crabby-images/0ea25/0ea25e86d22f13d8f770147aaf3784f0cebf7a00" alt=""
也就是说当我们在网页的表单中输入用户名和密码时,当查询结果不为空时,则在cookie中设置字段值
我们用burp抓包看看报文的详细信息
data:image/s3,"s3://crabby-images/3a9d4/3a9d4179d68075fbe476061afd3cb2cdc29327dd" alt=""
我们先查询一下users表里的信息
data:image/s3,"s3://crabby-images/35f7d/35f7d6d59f1e9150bd27530a8da19e1e3cde68c5" alt=""
接着输入一个users表中存在的用户名和密码
data:image/s3,"s3://crabby-images/f006b/f006b94ad1965c35d43a2153ec8ece326ff8a7bf" alt=""
这是我们提交表单给服务器的POST报文,来看看服务器这时返回的信息是什么
data:image/s3,"s3://crabby-images/50770/50770591f2b186cb73dd882884159f66e4ed1b34" alt=""
可以看出服务器设置了cookie信息
data:image/s3,"s3://crabby-images/5c0a7/5c0a7d8b78e47802dda8d1e1170f56a7920b08bc" alt=""
并且返回这些信息,可见这就是一开始的登录页面加上
data:image/s3,"s3://crabby-images/833ea/833eae70215954737680860c9b171052ab227f5f" alt=""
查询结果后返回的信息
那么我们放行这个请求报文,看看接下来发生什么
data:image/s3,"s3://crabby-images/6c556/6c5560885363f68232ca98d708b17832e59e859b" alt=""
放行后出现了第二个请求报文,这是个GET请求报文,我们可以看出此时头部已经有了cookie信息,我们再来看看服务器的回应
data:image/s3,"s3://crabby-images/4277c/4277c4a4bfe68c6ee5964ab7057429e518c61dd7" alt=""
我们再回头看看源代码,发现此时执行了第二个节点,此时cookie中的’uname’字段已经有了信息,则执行了else语句
这个else语句中又包含了一个节点
data:image/s3,"s3://crabby-images/46082/460829e394d89b38e6ef2cc6f42de26a80324f64" alt=""
也就是当我们还未点击submit按钮时会执行这个if语句
然后
data:image/s3,"s3://crabby-images/63727/637272089b68705f23cd420f106e3831e9194904" alt=""
返回一些信息
data:image/s3,"s3://crabby-images/656b0/656b02c7d690a88af2e58352c2c7dcdf6c561c7f" alt=""
并且以cookee变量的值作为用户名进行数据库的查询
然后将查询到的信息输出出来,最后一行会出现一个submit按钮
接下来我们放行第二个报文
data:image/s3,"s3://crabby-images/6368c/6368c3fd60d0ea3f8914d0bd16b1c8b6566548e4" alt=""
放行后可以看到网页发生了变化,也就是返回了还未提交submit时的信息
我们点击一下submit按钮,这时看看请求的报文格式
data:image/s3,"s3://crabby-images/68eae/68eaebadd5e3fce5b90e148bad321c5cd48113df" alt=""
可以看出这是一个POST请求报文,这时还又cookie信息,我们再来看看服务器返回的报文
data:image/s3,"s3://crabby-images/e7228/e72283e8868ea90c8832f4a97fc2879802b85f3a" alt=""
这时服务器发现cookie中的’expires’字段中的时间发生了变化,’uname’字段内容为空时,默认内容为deleted,并且返回
data:image/s3,"s3://crabby-images/99e0c/99e0ce31d7dec14e89fcdb1e60aec530ce2f0a19" alt=""
可见当我们点击submit按钮后执行了else语句
data:image/s3,"s3://crabby-images/1adb1/1adb1d80f8093583b0eb6f3c465ed720dc28c846" alt=""
放行这个POST请求报文
data:image/s3,"s3://crabby-images/dea60/dea6045ed092f833e8101a675de1520d8fba8146" alt=""
又出现了一个GET请求报文,看出此时cookie信息已经被删除了
data:image/s3,"s3://crabby-images/3d63a/3d63a80912cfd1202444c6fa4b5f0b14f812d1e0" alt=""
又回到了一开始的登录界面
这里就涉及了一个重定向“location”它的作用是不用用户输入网址,它会自动访问,一般是GET请求,所以我们之前能抓到两个请求报文,且网页最后显示是重定向后的最终页面