当前位置:主页   - 电脑 - 网络技术 - 网络安全
系统安全性测试问题举例
来源:网络   作者:   更新时间:2010-09-27
收藏此页】    【字号    】    【打印】    【关闭

  1:没有被验证的输入

  测试方法:

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

  允许的字符集

  最小和最大的长度

  是否允许空输入

  参数是否是必须的

  重复是否允许

  数值范围

  特定的值(枚举型)

  特定的模式(正则表达式)

  2:有问题的访问控制

  测试方法:

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

  例:从一个页面链到另一个页面的间隙可以看到URL地址

  直接输入该地址,可以看到自己没有权限的页面信息

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

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

  4:跨站脚本(XSS)

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

  测试方法:

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

  ?转义字符:&(&);<(<);>(>); (空格) ;

  ?脚本语言:

  <scrīpt language=‘javascrīpt’>

  …Alert(‘’)

  </scrīpt>

  ·特殊字符:“ ‘ < > /

  ·最小和最大的长度

  ·是否允许空输入

  5,缓冲区溢出

  没有加密关键数据

  例:view-source:http地址可以查看源代码

  在页面输入密码,页面显示的是 *****, 右键,查看源文件就可以看见刚才输入的密码,

  6,注入式漏洞。

  例:一个验证用户登陆的页面,如果使用的sql语句为:

  Select * from table A where username=‘’ + username+‘’ and pass word ………

  Sql 输入

  ‘ or 1=1 ――

  就可以不输入任何password进行攻击

  7,不恰当的异常处理

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

  8,不安全的存储

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

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

  9,拒绝服务

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

  10,不安全的配置管理

  分析:Config中的链接字符串以及用户信息,邮件,数据存储信息都需要加以保护

  程序员应该作的:

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

其它资源
来源声明

版权与免责声明
1、本站所发布的文章仅供技术交流参考,本站不主张将其做为决策的依据,浏览者可自愿选择采信与否,本站不对因采信这些信息所产生的任何问题负责。
2、本站部分文章来源于网络,其版权为原权利人所有。由于来源之故,有的文章未能获得作者姓名,署“未知”或“佚名”。对于这些文章,有知悉作者姓名的请告知本站,以便及时署名。如果作者要求删除,我们将予以删除。除此之外本站不再承担其它责任。
3、本站部分文章来源于本站原创,本站拥有所有权利。
4、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明