生命就像一场云游 坎坷也是一种收获

安全测试常见的10个问题

上一篇 / 下一篇  2008-03-18 15:08:32 / 个人分类:Web安全性测试

MILY: 宋体; mso-bidi-font-family: 宋体; mso-bidi-font-size: 10.5pt; mso-font-kerning: 0pt">1.     问题:没有被验证的输入
测试方法:

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

2.      问题:有问题的访问控制
测试方法

主要用于需要验证
用户身份以及权限的页面,复制该页面的url地址,关闭该页面以后,查看是否可以直接进入该复制好的地址
例:从一个页面链到另一个页面的间隙可以看到URL地址,直接输入该地址,可以看到自己没有权限的页面信息,

3.     错误的认证和会话管理
分析:帐号列表:系统
不应该允许用户浏览到网站所有的帐号,如果必须要一个用户列表,推荐使用某种形式的假名(屏幕名)来指向实际的帐号。
浏览器缓存:认证和会话数据不应该作为GET的一部分来发送,应该使用POST

4.      问题:跨站脚本(XSS
分析:攻击者使用跨站脚本来发送恶意代码给没有发觉的用户,窃取他机器上的任意
资料
测试方法:
• HTML
标签:<…>…</…>
• 
转义字符:&amp(&)&lt(<)&gt(>)&nbsp(空格)

• 
脚本语言
      <script. language=‘javascript’>
       …Alert(‘’)
       </script>
• 
特殊字符:‘  ’ <  >  /
• 
最小和最大的长度

• 
是否允许空输入

  
例:对GridLabelTree view类的输入框未作验证,输入的内容会按照html语法解析出来

5.     缓冲区溢出
分析:用户使用缓冲区溢出来破坏web应用程序的栈,通过发送特别编写的代码到web程序中,攻击者可以让web应用程序来执行任意代码。

6.     注入式漏洞。
例:一个验证用户登陆的页面,
如果使用的
sql语句为:
Select *  from  table A where  username
’’ + username+’’ and pass word …..
Sql
输入  ‘ or 11 ――  就可以不输入任何password进行攻击

7.     不恰当的异常处理
分析:程序在抛出异常的时候给出了比较详细的内部错误信息,暴露了不应该显示的执行细节,网站存在潜在漏洞

8.     安全的存储
没有加密关键数据
例:viewsourcehttp地址可以查看源代码
   
在页面输入密码,页面显示的是 *****,  右键,查看源文件就可以看见刚才输入的密码

9.     拒绝服务
分析:攻击者可以从一个主机产生足够多的流量来耗尽狠多应用程序,最终使程序陷入瘫痪。需要做负载均衡来对付。

10.  不安全的配置管理
分析:Config中的链接字符串以及用户信息,邮件,数据存储信息都需要加以保护

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

 

 


TAG:

 

评分:0

我来说两句

显示全部

:loveliness: :handshake :victory: :funk: :time: :kiss: :call: :hug: :lol :'( :Q :L ;P :$ :P :o :@ :D :( :)

日历

« 2011-03-21  
  12345
6789101112
13141516171819
20212223242526
2728293031  

数据统计

  • 访问量: 7879
  • 日志数: 64
  • 建立时间: 2007-09-05
  • 更新时间: 2008-04-01

RSS订阅

Open Toolbar