一、阐述常见的Web安全测试有几种类型?
日常网购或者网上交易时,为防止信息泄露,所以在WEB的安全测试中需要考虑以下情形,一共有七种:
1、数据加密:某些数据需要进行信息加密和过滤后才能在客户端和服务器之间进行传输,包括用户登录密码、信用卡信息等。
2、登录或身份验证:一般的应用站点都会使用登录或者注册后使用的方式。必须对用户名和匹配的密码进行校验,以阻止非法用户登录。进行登录测试的时候,需要考虑输入的密码是否大小写敏感、是否有长度和条件限制,最多可以尝试多少次登录,哪些页面或者文件需要登录后才能访问下载等。
3、输入验证:在进行Web安全性测试时,每个输入域都需要用标准的机制验证,长度、数据类型等符合设定要求,不允许输入JavaScript代码,包括验证从数据库中检索的数据、传递到组件或Web服务的参数等。
4、SQL注入:从客户端提交特殊的代码,从而收集程序及服务器的信息,从而获取必要的数据库信息,然后基于这些信息,可以注入某些参数,绕过程序的保护,针对数据库服务器进行攻击。
5、超时限制:Web应用系统一般会设定“超时”限制,当用户长时间不做任何操作时,需要重新登录才能打开其他页面。
6、目录:如果Web程序或Web服务器的处理不适当,可以通过简单的URL替换和推测,使整个Web目录暴露出来,带来严重的安全隐患。
7、操作留痕:为了保证Web应用系统的安全性,日志文件是至关重要。需要测试相关信息是否写进入了日志文件,是否可追踪。
二、安全测试工具调研
1. 概述
列出常见的安全测试工具,画一张表,加以说明。格式如下:
序号 | 安全测试工具 | 商用 OR 免费 | 检测对象(二进制代码/源代码) | 简介 |
---|---|---|---|---|
1 | Metasploit | 免费 | 源代码 | 攻击框架,包含大量的插件,做渗透测试 |
2 | Nessus | 商用 | 源代码 | 针对服务器主机类漏洞检查工具 |
3 | W3AF | 免费 | 源代码 | 针对WEB应用的检测 |
4 | Paros proxy | 免费 | 源代码 | 基于java的web代理程序,可以评估web应用程序的漏洞 |
5 | WebScarab | 免费 | 源代码 | 基于代理劫持的分析,来进行攻击路径的检测 |
6 | Nikto | 免费 | 源代码 | 旨在发现Web服务器的配置错误,插件和网页漏洞 |
7 | Wapiti | 免费 | 源代码 | 扫描指定目标的网页,并寻找脚本和表单来诸如数据,看看是否有漏洞 |
8 | Nmap | 免费 | 二进制代码 | 属于主机扫描工具,可以进行全面的检查 |
... |
2. 安全测试工具试用
选择Nessus,原因:可以对本机的服务器进行漏洞扫描。
导出
测试安全漏洞扫描,导出格式报告