博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
安全测试之Top 10 漏洞的分析
阅读量:5080 次
发布时间:2019-06-12

本文共 1212 字,大约阅读时间需要 4 分钟。

1. 问题:没有被验证的输入

 测试方法:

 数据类型(字符串,整型,实数,等)

 允许的字符集
 最小和最大的长度
 是否允许空输入
 参数是否是必须的
 重复是否允许
 数值范围
 特定的值(枚举型)
 特定的模式(正则表达式)

 

2. 问题:有问题的访问控制

 测试方法:

 主要用于需要验证用户身份以及权限的页面,复制该页面的url地址,关闭该页面以后,查看是否可以直接进入该复制好的地址。

 例:从一个页面链到另一个页面的间隙可以看到URL地址 直接输入该地址,可以看到自己没有权限的页面信息。

 

3. 错误的认证和会话管理

分析:帐号列表:系统不应该允许用户浏览到网站所有的帐号,如果必须要一个用户列表,推荐使用某种形式的假名(屏幕名)来指向实际的帐号。

浏览器缓存:认证和会话数据不应该作为GET的一部分来发送,应该使用POST。

 

4. 问题:跨站脚本(XSS)

 分析:攻击者使用跨站脚本来发送恶意代码给没有发觉的用户,窃取他机器上的任意资料

 测试方法:

•        HTML标签:<…>…</…> 

•        转义字符:&amp(&);&lt(<);&gt(>);&nbsp(空格);

•        脚本语言:

         <script language=‘javascript’>

         …Alert(‘’)

         </script>

•        特殊字符:‘ ’ < > /

•        最小和最大的长度

•        是否允许空输入

例:对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中的链接字符串以及用户信息,邮件,数据存储信息都需要加以保护

  程序员应该作的:配置所有的安全机制,关掉所有不使用的服务,设置角色权限帐号,使用日志和警报。


转载于:https://www.cnblogs.com/wysk/p/7792218.html

你可能感兴趣的文章
LinkedList源码分析
查看>>
TF-IDF原理
查看>>
用JS制作博客页面背景随滚动渐变的效果
查看>>
JavaScript的迭代函数与迭代函数的实现
查看>>
一步步教你学会browserify
查看>>
Jmeter入门实例
查看>>
亲近用户—回归本质
查看>>
中文脏话识别的解决方案
查看>>
CSS之不常用但重要的样式总结
查看>>
Python编译错误总结
查看>>
URL编码与解码
查看>>
日常开发时遇到的一些坑(三)
查看>>
Eclipse 安装SVN插件
查看>>
深度学习
查看>>
TCP粘包问题及解决方案
查看>>
构建之法阅读笔记02
查看>>
添加按钮
查看>>
移动端页面开发适配 rem布局原理
查看>>
Ajax中文乱码问题解决方法(服务器端用servlet)
查看>>
会计电算化常考题目一
查看>>