0x00 目录遍历漏洞概述
在web功能设计中,很多时候我们会要将需要访问的文件定义成变量,从而让前端的功能便的更加灵活。
当用户发起一个前端的请求时,便会将请求的这个文件的值(比如文件名称)传递到后台,后台再执行其对应的文件。
在这个过程中,如果后台没有对前端传进来的值进行严格的安全考虑,则攻击者可能会通过“../”这样的手段让后台打开或者执行一些其他的文件。 从而导致后台服务器上其他目录的文件结果被遍历出来,形成目录遍历漏洞。
看到这里,你可能会觉得目录遍历漏洞和不安全的文件下载,甚至文件包含漏洞有差不多的意思
是的,目录遍历漏洞形成的最主要的原因跟这两者一样,都是在功能设计中将要操作的文件使用变量的方式传递给了后台,而又没有进行严格的安全考虑而造成的,只是出现的位置所展现的现象不一样,因此,这里还是单独拿出来定义一下。
需要区分一下的是,如果你通过不带参数的url(比如:http://xxxx/doc)列出了doc文件夹里面所有的文件,这种情况,我们成为敏感信息泄露。 而并不归为目录遍历漏洞。
0x01 …/…/
随意点击链接后,可以看到url
中有文件名
但是不管怎么测试目录遍历都无法成功。。。
从上面能看出来是因为这里是使用文件包含的函数来进行完成的,所以只有目录没有文件就算包含失败了。这里我和作者的理解还是不一样的,于是我将dir_list.php
也去掉后,得到这样的一个页面。
我觉得这样才算是目录遍历,然后在后面不停的加上../
就可以查看到其他的目录了,当然这个地方是开启了目录浏览造成的,但是在ewebedior
编辑器也出现过类似的目录遍历漏洞。。。