您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 质量控制/管理 > 安全性测试初步接触.
初步分类:权限(黑盒+sql注入+目录遍历+非法文件与文字上传与写入)加密(网络传输、本地cookie、源文件、认证与会话)攻击(缓冲区溢出、sql注入、异常处理信息、端口扫描、服务器攻击、跨站脚本攻击、http回车换行注入攻击、代码注入、url重定向、google攻击)理论篇做的比较粗糙,大家在这块有什么可以交流下,消逝黑盒主要测试点用户管理模块,权限管理模块,加密系统,认证系统等工具使用Appscan(首要)、AcunetixWebVulnerabilityScanner(备用)、HttpAnalyzerFull、TamperIESetup木桶原理安全性最低的模块将成为瓶颈,需整体提高他人模型(虽然比较旧了)安全管理与审计物理层安全网络层安全传输层安全应用层安全链路层物理层网络层传输层应用层表示层会话层审计与监控身份认证数据加密数字签名完整性鉴别端到端加密访问控制点到点链路加密物理信道安全访问控制数据机密性数据完整性用户认证防抵赖安全审计网络安全层次层次模型网络安全技术实现安全目标用户安全(一)可手工执行或工具执行输入的数据没有进行有效的控制和验证用户名和密码直接输入需要权限的网页地址可以访问上传文件没有限制(此次不需要)不安全的存储操作时间的失效性1.1)输入的数据没有进行有效的控制和验证数据类型(字符串,整型,实数,等)允许的字符集最小和最大的长度是否允许空输入参数是否是必须的重复是否允许数值范围特定的值(枚举型)特定的模式(正则表达式)(注:建议尽量采用白名单)1.21)用户名和密码-1检测接口程序连接登录时,是否需要输入相应的用户是否设置密码最小长度(密码强度)用户名和密码中是否可以有空格或回车?是否允许密码和用户名一致防恶意注册:可否用自动填表工具自动注册用户?(傲游等)遗忘密码处理有无缺省的超级用户?(admin等,关键字需屏蔽)有无超级密码?是否有校验码?1.22)用户名和密码-2密码错误次数有无限制?大小写敏感?口令不允许以明码显示在输出设备上强制修改的时间间隔限制(初始默认密码)口令的唯一性限制(看需求是否需要)口令过期失效后,是否可以不登陆而直接浏览某个页面哪些页面或者文件需要登录后才能访问/下载cookie中或隐藏变量中是否含有用户名、密码、userid等关键信息1.3)直接输入需要权限的网页地址可以访问避免研发只是简单的在客户端不显示权限高的功能项举例Bug:没有登录或注销登录后,直接输入登录后才能查看的页面的网址(含跳转页面),能直接打开页面;注销后,点浏览器上的后退,可以进行操作。正常登录后,直接输入自己没有权限查看的页面的网址,可以打开页面。通过Http抓包的方式获取Http请求信息包经改装后重新发送从权限低的页面可以退回到高的页面(如发送消息后,浏览器后退到信息填写页面,这就是错误的)1.4)上传文件没有限制(此次不需要)上传文件还要有大小的限制。上传木马病毒等(往往与权限一起验证)上传文件最好要有格式的限制;此次我们不需要验证此处,简单介绍下,跳过1.5)不安全的存储在页面输入密码,页面应显示“*****”;数据库中存的密码应经过加密;地址栏中不可以看到刚才填写的密码;右键查看源文件不能看见刚才输入的密码;帐号列表:系统不应该允许用户浏览到网站所有的帐号,如果必须要一个用户列表,推荐使用某种形式的假名(屏幕名)来指向实际的帐号1.6)操作时间的失效性检测系统是否支持操作失效时间的配置,同时达到所配置的时间内没有对界面进行任何操作时,检测系统是否会将用户自动失效,需要重新登录系统。支持操作失效时间的配置。支持当用户在所配置的时间内没有对界面进行任何操作则该应用自动失效。如,用户登陆后在一定时间内(例如15分钟)没有点击任何页面,是否需要重新登陆才能正常使用。(二)借助工具或了解后手工来进行测试不能把数据验证寄希望于客户端的验证不安全的对象引用,防止XSS攻击注入式漏洞(SQL注入)传输中与存储时的密码没有加密,不安全的通信目录遍历2.1)不能把数据验证寄希望于客户端的验证避免绕过客户端限制(如长度、特殊字符或脚本等),所以在服务器端验证与限制客户端是不安全,重要的运算和算法不要在客户端运行。Session与cookie例:保存网页并对网页进行修改,使其绕过客户端的验证。(如只能选择的下拉框,对输入数据有特殊要求的文本框)还可以查看cookie中记录,伪造请求测试中,可使用TamperIESetup来绕过客户端输入框的限制2.21)不安全的对象引用,防止XSS等攻击阻止带有语法含义的输入内容,防止CrossSiteScripting(XSS)Flaws跨站点脚本攻击(XSS)防止Cross-siterequestforgery(CSRF)跨站请求伪造xss解释:不可信的内容被引入到动态页面中,没有识别这种情况并采取保护措施。攻击者可在网上提交可以完成攻击的脚本,普通用户点击了网页上这些攻击者提交的脚本,那么就会在用户客户机上执行,完成从截获帐户、更改用户设置、窃取和篡改cookie到虚假广告在内的种种攻击行为2.22)不安全的对象引用,防止XSS等攻击测试方法:在输入框中输入下列字符,可直接输入脚本来看HTML标签:……/…转义字符:&(&);<();>(); (空格);脚本语言:scriptalert(document.cookie);/script特殊字符:‘’/最小和最大的长度是否允许空输入对Grid、Label、Treeview类的输入框未作验证,输入的内容会按照html语法解析出来,要控制脚本注入的语法要素。比如:javascript离不开:“”、“”、“(”、“)”、“;”.在输入或输出时对其进行字符过滤或转义处理2.23)注入式漏洞(SQL注入)对数据库等进行注入攻击。例:一个验证用户登陆的页面,如果使用的sql语句为:Select*fromtableAwhereusername=’’+username+’’andpassword…..则在Sql语句后面输入‘or1=1――就可以不输入任何password进行攻击SELECTcount(*)FROMusersWHEREusername='a'or'a'='a'ANDpassword='a'or'a'='a'(资料太多,不显示了此处,借助工具Appscan等吧)2.24)传输中与存储时的密码没有加密利用ssl来进行加密,在位于HTTP层和TCP层之间,建立用户与服务器之间的加密通信进入一个SSL站点后,可以看到浏览器出现警告信息,然后地址栏的http变成https(特点确定)证书认证————————————————————————检查数据库中的用户密码、管理者密码等字段是否是以加密方式保存。存储数据库单独隔离,有备份的数据库,权限唯一2.25)目录遍历举例:=MyFolder那现在把这个URL改装一下:里的所有文件都出来了简要的解决方案:1、限制Web应用在服务器上的运行,格设定WEB服务器的目录访问权限2、进行严格的输入验证,控制用户输入非法路径,如在每个目录访问时有index.htm(三)研发或使用工具才能进行认证和会话数据不能作为GET的一部分来发送隐藏域与CGI参数不恰当的异常处理不安全的配置管理缓冲区溢出拒绝服务日志完整性、可审计性与可恢复性3.1)Getorpost认证和会话数据不应该作为GET的一部分来发送,应该使用POST例:对Grid、Label、Treeview类的输入框未作验证,输入的内容会按照html语法解析出来可使用TamperIESetup或ScannerHttpAnalyzerFull来判断3.2)隐藏域与CGI参数Bug举例:分析:隐藏域中泄露了重要的信息,有时还可以暴露程序原代码。直接修改CGI参数,就能绕过客户端的验证了。如:inputtype=hiddenname=hvalue=只要改变value的值就可能会把程序的原代码显示出来。如大小写,编码解码,附加特殊字符或精心构造的特殊请求等都可能导致CGI源代码泄露可使用appscan或sss等来检测,检查特殊字符集3.3)不恰当的异常处理分析:程序在抛出异常的时候给出了比较详细的内部错误信息,暴露了不应该显示的执行细节,网站存在潜在漏洞,有可能会被攻击者分析出网络环境的结构或配置通常为其他攻击手段的辅助定位方式举例:如**w.com,搜索为空时,,数据库显示出具体错误位置,可进行sql注入攻击或关键字猜测攻击3.4)不安全的配置管理分析:Config中的链接字符串以及用户信息,邮件,数据存储信息都需要加以保护配置所有的安全机制,关掉所有不使用的服务,设置角色权限帐号,使用日志和警报。手段:用户使用缓冲区溢出来破坏web应用程序的栈,通过发送特别编写的代码到web程序中,攻击者可以让web应用程序来执行任意代码例:数据库的帐号是不是默认为“sa”,密码(还有端口号)是不是直接写在配置文件里而没有进行加密。3.5)缓冲区溢出WEB服务器没有对用户提交的超长请求没有进行合适的处理,这种请求可能包括超长URL,超长HTTPHeader域,或者是其它超长的数据使用类似于“strcpy(),strcat()”不进行有效位检查的函数,恶意用户编写一小段程序来进一步打开安全缺口,然后将该代码放在缓冲区有效载荷末尾,这样,当发生缓冲区溢出时,返回指针指向恶意代码用户使用缓冲区溢出来破坏web应用程序的栈,通过发送特别编写的代码到web程序中,攻击者可以让web应用程序来执行任意代码。如apach缓冲区溢出等错误,第三方软件也需检测3.6)拒绝服务手段:超长URL,特殊目录,超长HTTPHeader域,畸形HTTPHeader域或者是DOS设备文件分析:攻击者可以从一个主机产生足够多的流量来耗尽狠多应用程序,最终使程序陷入瘫痪。需要做负载均衡来对付。详细如:死亡之ping、泪滴(Teardorop)、UDP洪水(UDPFlood)、SYN洪水(SYNFlood)、Land攻击、Smurf攻击、Fraggle攻击、畸形消息攻击3.7)日志完整性。可审计性与可恢复性服务器端日志:检测系统运行时是否会记录完整的日志。如进行详单查询,检测系统是否会记录相应的操作员、操作时间、系统状态、操作事项、IP地址等检测对系统关键数据进行增加、修改和删除时,系统是否会记录相应的修改时间、操作人员和修改前的数据记录。工具篇WatchfireAppscan——全面自动测试工具AcunetixWebVulnerability——全面自动测试工具ScannerHttpAnalyzerFull——加载网页时可判断TamperIESetup——提交表单时改造数据注:上述工具最好安装在虚拟机中,不影响实际机环境Appscan、WebVulnerability需安装.netframework,可能与sniffer冲突ScannerHttpAnalyzerFul与TamperIESetup会影响实际机浏览器平时的功能测试(一)WatchfireAppscan选择模板,default(含大部分的测试集合)填入用户名与密码(各页面通用)(二)AcunetixWebVulnerability选择webscan,填写用户名与密码(三)ScannerHttpAnalyzerFull嵌
本文标题:安全性测试初步接触.
链接地址:https://www.777doc.com/doc-2491889 .html