我们将演示如何手工渗透测试web应用程序而不使用自动化工具 。世界上大多数公司都非常关注对web应用程序的手工测试,而不是运行web应用程序扫描器——因为它会限制你的知识和技能,影响在测试中寻找漏洞的视野 。
我将使用下面的程序:
NOWASP MutiliadaeNOWASP MutiliadaeNOWASP Mutiliadae是一个包含了40多个漏洞的web应用程序 。它包括OWASP的top 10漏洞,也有其它组织的列表中的漏洞 。其中有可以利用web应用程序扫描器(比如Vega, Acunetix, Nikto, w3af等)扫描出的小型和中型漏洞 。我将使用这个程序的最新版本,它以面向对象的方式设计,这可以让我们更好地理解web应用程序的所有漏洞 。
BURP Proxy

文章插图
Burp Suite我将用到的另外一个工具是Burp Proxy 。它是一个介于客户端(浏览器程序,比如Firefox或者Chrome)和网站或服务器之间的代理 。它将在我的本地计算机上运行,截获浏览器和目标机(在我们的环境中,目标机是NOWASP Mutiliadae)之间的出站或入站流量 。这个工具的主要作用在于,当你请求访问一个服务器时,Burp Suite拦截从你的机器发往服务器的请求,你可以根据需要改变请求的内容 。它也可以显示请求的类型,是GET或是POST请求,或者是其它类型的请求 。Burp也有另外一个功能,可以显示你发往网站的参数列表 。你可以根据检查web应用程序的安全性的需要操作请求内容 。为了拦截请求,你的Burp Proxy listener必须配置成监听127.0.0.1 localhost的8080端口 。然后你还需要设置浏览器的代理配置,完成之后,选择Suite => proxy tab => Intercept,开启拦截 。我不会深入介绍所有的tab选项卡以及他们的功能 。你可以查看Burp的手册和文档 。

文章插图
Web的工作流程在开始之前,你应该了解web在后端是如何工作的,这些你在web浏览器是看不到的 。当你访问一个网站时,你的浏览器访问web服务器上的一个文件,这个文件可以是html, php, js (JAVAScript), css, ASPX等等 。使用Burp Suite,我们能观察到下图所示的请求 。为了查看请求,我按上面的方法配置了Burp和浏览器,然后访问下图所示的HTML5 storage page 。

文章插图
一旦我点击了超链接,Burp就会拦截这个请求,内容如下 。你可以看到它是一个访问服务器上的index.php页面的请求 。这里的参数是page,参数的值是html5-storage.PHP 。
GET /chintan/index.php?page=html5-storage.php HTTP/1.1Host: localhostUser-Agent: Mozilla/5.0 (windows NT 5.1; rv:27.0) Gecko/20100101 Firefox/27.0Accept: text/html,Application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8Accept-Language: en-US,en;q=0.5Accept-Encoding: gzip, deflateReferer: http://localhost/chintan/Cookie: showhints=0; username=chintan; uid=19; PHPSESSID=j53u16lcdkjq0eec6nfijphkd4Connection: keep-alive我想要访问这个页面,所以我转发这个请求 。如何你查看response选项卡,会发现我收到了一个“200 OK”的响应 。 HTTP/1.1 200 OKDate: Sat, 28 Dec 2013 23:30:08 GMTServer: Apache/2.4.3 (Win32) OpenSSL/1.0.1c PHP/5.4.7X-Powered-By: PHP/5.4.7Logged-In-User: chintanKeep-Alive: timeout=5, max=100Connection: Keep-AliveContent-Type: text/htmlContent-Length: 46178“200 OK”表示我的请求被成功执行,并给我返回了响应 。如果观察浏览器,就会发现所有的web页面都已经加载了 。注意:你每次发送请求的时候,都会动态创建一个HTML文件 。后台的PHP文件会接收到你的请求,创建一个HTML文件并发送给你的浏览器,浏览器负责渲染页面 。你在web浏览器上看到的并不是一个web页面,而是浏览器对页面该怎样图形化展示的解释 。“不要只看在web浏览器上看到的图像,要经常练习以源代码的方式查看web页面以便熟悉它 。你要尽可能熟悉JavaScript, XML, 以及所有的HTML标签 。”
如何入手当开始测试时,初学者普遍存在的问题是该从哪里入手 。我们都知道黑客的工作周期 。第一个阶段是信息收集或者侦查 。在这个例子中,我将尽可能多得获取关于网站和服务器的信息,并不需要浏览所有的web页面 。如果你注意到上面的请求和响应,我们已经得到了一些东西 。有如下信息:

文章插图
有很多种收集信息的方法 。人们大多使用google,Recon-ng框架等应用程序安全测试工具 。我将使用Burp Suite中的spider列出目标的所有页面和文件夹 。首先,打开history,选中你访问的第一个页面 。右击它,选择add to the scope选项 。
推荐阅读
- 想学习黑客技术吗?告诉你什么才是真正的黑客!
- 细说玫瑰花茶的十大作用,玫瑰花茶的作用哪些
- 淘宝大秒系统设计详解
- 2020 年,网络安全方面 5 大值得学习的编程语言
- 胖大海的副作用有哪些,玫瑰花茶的副作用有哪些
- Excel的修图功能这么强大!网友:这么多年Excel白用了
- 电脑怎么从bios还原系统
- 产前喝茉莉苞茶大出血,喝花卉茶要注意什么
- 华擎主板bios如何设置U盘启动
- 各大品牌电脑进入BIOS
