安全测试学习笔记二(对于top 10 漏洞的分析)
来源:互联网 发布:java权限修饰符 编辑:程序博客网 时间:2024/04/29 15:51
1, 问题:没有被验证的输入
测试方法:
数据类型(字符串,整型,实数,等)
允许的字符集
最小和最大的长度
是否允许空输入
参数是否是必须的
重复是否允许
数值范围
特定的值(枚举型)
特定的模式(正则表达式)
2, 问题:有问题的访问控制
测试方法:
主要用于需要验证用户身份以及权限的页面,复制该页面的url地址,关闭该页面以后,查看是否可以直接进入该复制好的地址
例:从一个页面链到另一个页面的间隙可以看到URL地址
直接输入该地址,可以看到自己没有权限的页面信息,
3 错误的认证和会话管理
分析:帐号列表:系统不应该允许用户浏览到网站所有的帐号,如果必须要一个用户列表,推荐使用某种形式的假名(屏幕名)来指向实际的帐号。
浏览器缓存:认证和会话数据不应该作为GET的一部分来发送,应该使用POST,
4 问题:跨站脚本(XSS)
分析:攻击者使用跨站脚本来发送恶意代码给没有发觉的用户,窃取他机器上的任意资料
测试方法:
• HTML标签:<…>…
• 转义字符:&(&);<(<);>(>); (空格) ;
• 脚本语言:
• 特殊字符:‘ ’ < > /
• 最小和最大的长度
• 是否允许空输入
例:对Grid、Label、Tree view类的输入框未作验证,输入的内容会按照html语法解析出来
5,缓冲区溢出
分析:用户使用缓冲区溢出来破坏web应用程序的栈,通过发送特别编写的代码到web程序中,攻击者可以让web应用程序来执行任意代码。
6,注入式漏洞
例:一个验证用户登陆的页面,
如果使用的sql语句为:
Select * from table A where username=’’ + username+’’ and pass word …..
Sql 输入 ‘ or 1=1 ―― 就可以不输入任何password进行攻击
7,不恰当的异常处理
分析:程序在抛出异常的时候给出了比较详细的内部错误信息,暴露了不应该显示的执行细节,网站存在潜在漏洞,
8,不安全的存储
没有加密关键数据
例:view-source:http地址可以查看源代码
在页面输入密码,页面显示的是 *****, 右键,查看源文件就可以看见刚才输入的密码
9,拒绝服务
分析:攻击者可以从一个主机产生足够多的流量来耗尽狠多应用程序,最终使程序陷入瘫痪。需要做负载均衡来对付。
10,不安全的配置管理
分析:Config中的链接字符串以及用户信息,邮件,数据存储信息都需要加以保护
程序员应该作的: 配置所有的安全机制,关掉所有不使用的服务,设置角色权限帐号,使用日志和警报。
(本文转载自网络,感谢原文作者)
- 安全测试学习笔记二(对于top 10 漏洞的分析)
- 安全测试学习笔记二(对于top 10 漏洞的分析)
- OWASP top 10 漏洞的总结笔记
- OWASP top 10 漏洞的总结笔记
- Web入侵安全测试与对策学习笔记之(二)——获取目标信息之其他人留下的漏洞—样例程序的缺陷
- 【安全牛学习笔记】手动漏洞挖掘(二)
- 【安全牛学习笔记】手动漏洞挖掘(二)
- 安全测试学习之XSS漏洞测试
- 【安全牛学习笔记】漏洞挖掘
- 【安全牛学习笔记】漏洞概念
- 【安全牛学习笔记】漏洞扫描
- 【安全牛学习笔记】上传漏洞基础知识
- 【安全牛学习笔记】上传漏洞基础知识
- 【安全牛学习笔记】扫描漏洞
- 【安全牛学习笔记】上传漏洞基础知识
- Drozer二 亲测------测试android应用程序漏洞的安全评估工具---Drozer配置安装篇
- 《0day安全:软件漏洞分析技术》学习笔记-第五章堆溢出利用
- 对于web安全测试的一些感悟
- 关于Tomcat的Pipeline机制
- 通过Junit和Spring-Test测试SpringMVC的web应用
- Maven学习 (五) Elipse中发布一个Maven项目到Tomcat
- KM(N^3)模板(HDU2255)
- android中画虚线--.PathEffect类简单认识
- 安全测试学习笔记二(对于top 10 漏洞的分析)
- poj 2236 Wireless Network
- ARC 类型转换:显示转换 id 和 void *
- 根据CI模式弄的一个python访问数据的class
- VS批生成(Batch Build)不可使用的问题
- UITextView控件的用法
- JSON小小结 - - - jackson, gson, json-lib
- UIWindow
- 不明白的三层