ImageVerifierCode 换一换
格式:DOCX , 页数:10 ,大小:25.16KB ,
资源ID:5129813      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/5129813.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(典型网站漏洞分类影响及解决方案.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

典型网站漏洞分类影响及解决方案.docx

1、典型网站漏洞分类影响及解决方案典型网站漏洞分类影响及解决方案 本文由s8h4a2n6贡献 doc文档可能在WAP端浏览体验不佳。建议您优先选择TXT,或下载源文件到本机查看。 一、 典型网站漏洞分类 根据风险等级,网站漏洞一般可分为高风险、中风险和低风险三种。其中高 风险漏洞是必须封堵的。中、低风险漏洞中有一部分是必须封堵的。还有一部分 中、低风险漏洞,由于其封堵的代价可能远高于不封堵所造成的损失,因而能够 进行选择性封堵。能够采取工具亿思平台进行其网站的漏洞扫描, 具体地址为: 典型网站漏洞的分类及相应的封堵要求如下表所示: 风险等级 高风险 1、 SQL 注入漏洞 2、 跨站漏洞 中、低风

2、险 1、 默认测试用例文件 2、 管理后台登陆入口 中、低风险 1、 存在电子邮件地 址 漏洞名称 3、 XPATH 注入漏 3、 应用程序错误引起的 2、 无效链接 洞 信息泄露 4、 备份文件造成的源代 码泄漏 3、 Web 应用默认目 录 封堵要求 必须封堵 选择封堵 1 二、 典型网站漏洞影响及解决方案 1、 SQL 注入漏洞 漏洞影响: 本漏洞属于 Web 应用安全中的常见漏洞,属于 OWASP TOP 10 ( ) 中的注入类漏洞。 很多 WEB 应用中都存在 SQL 注入漏洞。SQL 注入是一种攻击者利用代码 缺陷进行攻击的方式,可在任何能够影响数据库查询的应用程序参数中利用。例

3、 如 url 本身的参数、post 数据或 cookie 值。 正常的 SQL 注入攻击很大程度上取决于攻击者使用从错误消息所获得信 息。可是,即使没有显示错误消息应用程序仍可能受 SQL 注入的影响。 总体上讲,SQL 注入是对 web 应用而不是对 web 服务器或操作系统本身 的攻击。正如其名称所示,SQL 注入是对查询添加非预期 SQL 命令从而以数据 库管理员或开发人员非预期的方式操控数据库的行为。如果成功的话,就能够获 得、修改、注入或删除有漏洞 web 应用所使用数据库服务器的数据。在某些环 境下,可利用 SQL 注入完全控制系统。 解决方案: 防护建议包括部署分层安全措施(包括

4、在接受用户输入时使用参数化的查 询) 、确保应用程序仅使用预期的数据、加固数据库服务器防止不恰当的访问数 据。 建议使用以下措施防范 SQL 注入漏洞: 2 对于开发 = 使用以下建议编写不受 SQL 注入攻击影响的 web 应用。 参数化查询: SQL 注入源于攻击者控制查询数据以修改查询逻辑, 因此防范 SQL 注入攻击的最佳方式就是将查询的逻辑与其数据分隔, 这能够防止执行从用户输 入所注入的命令。这种方式的缺陷是可能对性能产生影响(但影响很小) ,且必 须以这种方式构建站点上的每个查询才能完全有效。只要无意中绕过了一个查 询,就足以导致应用受 SQL 注入的影响。以下代码显示的是能够进

5、行 SQL 注入 的 SQL 语句示例。 sSql = SELECT LocationName FROM Locations ; sSql = sSql + WHERE LocationID = + RequestLocationID; oCmd.CommandText = sSql; 下面的例子使用了参数化的查询,不受 SQL 注入攻击的影响。 sSql = SELECT * FROM Locations ; sSql = sSql + WHERE LocationID = LocationID; oCmd.CommandText = sSql; oCmd.Parameters.Add(Lo

6、cationID, RequestLocationID); 应 用 程 序 没 有 包 含 用 户 输 入 向 服 务 器 发 送 SQL 语 句 , 而 是 使 用 -LocationID-参数替代该输入,这样用户输入就无法成为 SQL 执行的命令。 3 这种方式能够有效的拒绝攻击者所注入的任何输入,尽管仍会生成错误,但仅为 数据类型转换错误,而不是黑客能够利用的错误。 以下代码示例显示从 HTTP 查询字符串中获得产品 ID 并使用到 SQL 查询 中。 请注意传送给 SqlCommand 的包含有 SELECT 的字符串仅仅是个静态字符 串,不是从输入中截取的。另外还请注意使用 SqlP

7、arameter 对象传送输入参数 的方式,该对象的名称(pid)匹配 SQL 查询中所使用的名称。 C#示例: string connString = WebConfigurationManager.ConnectionStringsmyConn.ConnectionStr ing; using (SqlConnection conn = new SqlConnection(connString) conn.Open(); SqlCommand cmd = new SqlCommand(SELECT Count(*) FROM Products WHERE ProdID=pid, conn)

8、; SqlParameter prm = new SqlParameter(pid, SqlDbType.VarChar, 50); prm.Value = Request.QueryStringpid; cmd.Parameters.Add(prm); int recCount = (int)cmd.ExecuteScalar(); 4 VB.NET 示例: Dim connString As String = WebConfigurationManager.ConnectionStrings(myConn).ConnectionStr ing Using conn As New SqlCo

9、nnection(connString) conn.Open() Dim cmd As SqlCommand = New SqlCommand(SELECT Count(*) FROM Products WHERE ProdID=pid, conn) Dim prm As SqlParameter = New SqlParameter(pid, SqlDbType.VarChar, 50) prm.Value = Request.QueryString(pid) cmd.Parameters.Add(prm) Dim recCount As Integer = cmd.ExecuteScala

10、r() End Using 验证输入:可经过正确验证用户输入的类型和格式防范大多数 SQL 注入攻击, 最佳方式是经过白名单, 定义方法为对于相关的字段只接受特定的帐号号码或帐 号类型,或对于其它仅接受英文字母表的整数或字母。很多开发人员都试图使用 黑名单字符或转义的方式验证输入。总体上讲,这种方式经过在恶意数据前添加 转义字符来拒绝已知的恶意数据,如单引号,这样之后的项就能够用作文字值。 5 这种方式没有白名单有效,因为不可能事先知道所有形式的恶意数据。 对于安全操作 = 使用以下建议帮助防范对 web 应用的 SQL 注入攻击。 限制应用程序权限:限制用户凭据,仅使用应用运行所必须权限的。

11、任何成功的 SQL 注入攻击都会运行在用户凭据的环境中,尽管限制权限无法完全防范 SQL 注入攻击,但能够大大增加其难度。 强系统管理员口令策略: 一般攻击者需要管理员帐号的功能才能使用特定的 SQL 命令,如果系统管理员口令较弱的话就比较容易暴力猜测,增加成功 SQL 注入 攻击的可能性。另一个选项就是根本不使用系统管理员口令,而是为特定目的创 建特定的帐号。 一致的错误消息方案:确保在出现数据库错误时向用户提供尽可能少的信息。不 要泄漏整个错误消息,要同时在 web 和应用服务器上处理错误消息。当 web 服 务器遇到处理错误时,应使用通用的 web 页面响应,或将用户重新定向到标准 的位

12、置。绝不要泄漏调试信息或其它可能对攻击者有用的细节。 有关如何在 IIS 中关闭详细错误消息的说明请见: 6 使用以下句法在 Apache 服务器上取缔错误消息: Syntax: ErrorDocument Example: ErrorDocument 500 /webserver_errors/server_error500.txt WebSphere 之类的应用服务器一般默认安装启用了错误消息或调试设置。有关 如何取缔这些错误消息的信息,请参考应用服务器文档。 存储过程:如果不使用的话,请删除 master.Xp_cmdshell、xp_startmail、 xp_sendmail、sp_

13、makewebtask 之类的 SQL 存储过程。 SQL 注入漏洞根本上还是取决于 web 应用程序的代码。尽管不是修复,但 能够经过向 IDS 中添加结合了正则表示式的规则作为紧急措施检测 SQL 注入攻 击。尽管这无法修复所有可能的 SQL 注入漏洞,但便于实施,而且要求攻击者 必须要改进其方法才能实现成功的攻击。可如下使用正则表示式。 删除 SQL 元字符的正则表示式: /(%27)|()|(-)|(%23)|(#)/ix 7 可如下将上述正则表示式添加到 Snort 规则: alert tcp $EXTERNAL_NET any - $HTTP_SERVERS $HTTP_PORTS

14、 (msg:SQL Injection- Paranoid;flow:to_server,established;uricontent:.pl;pcre:/(%27)|()|(- -)|(%23)|(#)/i; classtype:Web-application-attack; sid:9099; rev:5;) 传统 SQL 注入攻击的正则表示式: /w*(%27)|()(%6F)|o|(%4F)(%72)|r|(%52)/ix 删除有 UNION 关键字的 SQL 注入攻击的正则表示式: /(%27)|()union/ix (%27)|() 可为其它的 SQL 查询(如 select、in

15、sert、update、delete、drop 等)编 写类似的正则表示式。 在 MS SQL 服务器上检测 SQL 注入攻击的正则表示式: /exec(s|+)+(s|x)pw+/ix 对于质量保证 = 8 解决 SQL 注入缺陷最终要求基于代码的修复, ”对于开发”和”对于安全操 作”部分所述的步骤提供了修复这些漏洞所必要的信息。以下步骤概述了如何对 应用程序手动测试 SQL 注入。 如何对应用程序手动测试 SQL 注入: 1. 在浏览器中打开希望测试 SQL 注入漏洞的 web 应用。 2. 将鼠标光标悬停在 Web 站点的链接上并注意底部的状态栏, 能够看到链接所 指 向 的 URL

16、。 找 到 其 中 带 有 参 数 的 URL , 如 注释:如果没有在状态栏中看到任何 URL,请点击链接然后查看地址栏,直到 找到带有参数的 URL。 3. 找到带有参数的 URL 后,点击链接进入网页,在地址栏中能够看到状态栏中 的 URL。 4. 有两种测试 SQL 注入脚本的方法, 请使用全部两种方式依次测试每个参数值。 方法 1. 在地址栏中点击光标,高亮显示参数值,如高亮显示 name=value 中的 value 并 9 用单引号()替换,这时应类似于 name=。 方法 2. 在地址栏中点击光标,在 value 中间输入单引号() ,这时应类似于 name=value。 5.

17、 点击 GO 键将请求发送到 Web 服务器。 6. 分析 Web 服务器响应中的错误消息, 大多数数据库错误消息都类似于以下示 例: Example error 1: Microsoft OLE DB Provider for SQL Server error 80040e14 Unclosed quotation mark before the character string 51 ORDER BY some_name. /some_directory/some_file.asp, line 5 Example error 2: ODBC Error Code = S1000 (Gene

18、ral error) OracleODBCOraORA-00933: SQL command not properly ended Example error 3: Error: 1353 SQLSTATE: HY000 (ER_VIEW_WRONG_LIST) Message: Views SELECT and views field list have different column counts 10 7. 有时错误消息并不明显,隐藏在页面源码中。如果要查看这些消息,必须查 看页面的 HTML 源码并搜索错误。 如果要在 Internet Explorer 中实现这个操作, 点击 ”查

19、看” 菜单, 然后选择 ”源码” 选项, 这能够打开记事本显示页面的 HTML 源码。在记事本中,打开”编辑”菜单并选择”查找” 。这时会出现一个对话框 询问”查找内容” 。输入 Microsoft OLE DB 或ODBC然后点击”查找下一个” 。 8. 如果 6 或 7 步成功,则 Web 站点存在 SQL 注入漏洞。 2、 跨站漏洞 漏洞影响: 跨站脚本攻击(也称为 XSS)指利用网站漏洞从用户那里恶意盗取信息。用 户在浏览网站、使用即时通讯软件、甚至在阅读电子邮件时,一般会点击其中的 链接。攻击者经过在链接中插入恶意代码,就能够盗取用户信息或在终端用户系 统上执行恶意代码。 成功的跨站

20、脚本攻击所带来的主要问题包括: 帐号劫持 - 攻击者能够在会话 cookie 过期之前劫持用户的会话,并以访问 ULR 用户的权限执行操作,如发布数据库查询并查看结果。 恶意脚本执行 - 用户可能在不知情的情况下执行攻击者注入到动态生成页 面中的 JavaScript、VBScript、ActiveX、HTML 甚至 Flash 内容。 蠕虫传播 - 经过 Ajax 应用,跨站脚本能够以类似于病毒的方式传播。跨站 11 脚本负载能够自动将其自身注入到页面中, 并经过更多的跨站脚本轻易的重新注 入同一主机,而所有这些都无需手动刷新页面。因此,跨站脚本能够使用复杂的 HTTP 方式发送多个请求,并

21、以用户不可视的方式自我传播。 信息窃取 - 攻击者能够经过重新定向和伪造站点将用户连接到攻击者所选择的 恶意服务器并获得用户所输入的任何信息。 拒绝服务 - 一般攻击者经过在包含有跨站脚本漏洞的站点上使用畸形的显示请 求,就能够导致主机站点重复的自我查询,出现拒绝服务的情况。 浏览器重新定向 - 在某些使用帧的站点上,用户可能在实际上已经被重新定向 到恶意站点的情况下误导为仍处在原始站点上,因为浏览权地址栏中的 URL 仍 保持不变。这是由于没有重新定向整个页面,而只是执行 JavaScript 的帧。 控制用户设置 - 攻击者能够恶意更改用户设置。 本漏洞属于 Web 应用安全常见漏洞。 解

22、决方案: 推荐措施包括实施安全编程技术确保正确过滤用户提供的数据, 并编码所有 用户提供的数据以防以可执行的格式向终端用户发送注入的脚本。 对于开发 12 = 可经过仔细验证所有输入和正确编码所有输出来防范跨站脚本攻击。 可使用 标准的 ASP.NET 验证控件或直接在代码中实施验证, 要尽可能使用严格的模版。 输出编码要确保在将内容发送给客户端之前对任何可脚本化的内容都进行了正 确的 HTML 编码。可经过 HttpUtility.HtmlEncode 函数实现,如以下 Label 控件示例所示: Label2.Text = HttpUtility.HtmlEncode(input) 考虑用

23、户输入经过应用可能用到的所有路径。例如,如果数据是由用户输入 的,存储在数据库中,然后再重新显示,就必须要确保在每次检索的时候都能正 确编码。如果必须允许自由格式文本输入(如在消息板中) ,而又希望允许使用 一些 HTML 格式,则能够经过仅明确允许很小的安全标签列表来安全的处理这 种情况,如下所示: C#示例: StringBuilder sb = new StringBuilder( HttpUtility.HtmlEncode(input); sb.Replace(, ); sb.Replace(, ); 13 sb.Replace(, ); sb.Replace(, ); Respon

24、se.Write(sb.ToString(); VB.NET 示例: Dim sb As StringBuilder = New StringBuilder( _ HttpUtility.HtmlEncode(input) sb.Replace(, ) sb.Replace(, ) sb.Replace(, ) sb.Replace(, ) Response.Write(sb.ToString() Java 示例: public static String HTMLEncode(String aTagFragment) final StringBuffer result = new Strin

25、gBuffer(); final StringCharacterIterator iterator = new StringCharacterIterator(aTagFragment); char character = iterator.current(); while (character != StringCharacterIterator.DONE ) if (character = = ) result.append() result.append(); 14 else if (character = = ) result.append(); else if (character

26、= = ) result.append(); else if (character = = ) result.append(); else if (character = = &) result.append(&); else /the char is not a special one /add it to the result as is result.append(character); character = iterator.next(); return result.toString(); 以下建议可帮助构建能够抵御跨站脚本攻击的 web 应用。 定义允许的内容。确保 web 应用

27、对所有输入参数(cookies、头、查询字符 串、表单、隐藏字段等)验证严格定义的预期结果。 检查 POST 和 GET 请求的响应,确保返回内容是预期的且有效。 经过编码用户提供的数据从用户输入中删除冲突字符、括号、单双引号。这 能够防范以可执行的方式向终端用户发送注入的脚本。 在可能的时候将所有客户端提供的数据仅限于字母数字的数据。使用这种过 滤方案时,如果用户输入了, 就会被减少为 scriptalertdocumentcookiescript。如果必须使用非字母数字字 符,在 HTTP 响应中使用之前将其编码为 HTML 实体,这样就无法将其用于修 改 HTML 文档的结构。 使用双重

28、用户认证机制而不是单重认证。 在修改或使用脚本之前确认其来源。 在自己的代码中使用时不要明确的信任任何来自她人的脚本,无论是从 web 下载还是来自熟人。 大多数服务器端脚本语言都提供了内嵌方式将输入变量的值转换为正确的不 15 可解释 HTML。应使用这种方式在将输入显示给客户端之前过滤所有输入。 PHP: string htmlspecialchars (string string , int quote_style) ASP / ASP.NET: Server.HTMLEncode (strHTML String) 对于安全操作 = 服务器端编码指的是首先经过编码函数发送所有的动态内容,

29、 使用所选择字 符集中的代码替换 Scripting 标签,这能够帮助防范跨站脚本攻击。服务器端编 码的缺点是可能耗费资源,对一些 web 服务器的性能产生负面影响。 如果必须允许站点用户使用 HTML 标签,如允许用户使用的格式化标签的 公告栏,则应限制可使用的标签。创立可接受标签的列表,如粗体字、斜体字或 下划线,并仅允许使用这些,拒绝任何其它标签。以下是一些可帮助检测跨站脚 本的正则表示式。 简单跨站脚本攻击的正则表示式: /(%3C)|)/ix 应如下将上述正则表示式添加到新的 Snort 规则: alert tcp $EXTERNAL_NET any - $HTTP_SERVERS

30、$HTTP_PORTS (msg:NIICross-Site Scripting attempt; flow:to_server,established;pcre:/(%3C)|)/i;classtype:Web-application-attack; sid:9000; rev:5;) 跨站脚本攻击的偏执行正则表示式: /(%3C)|)/I 这条特征仅仅查找起始的 HTML 标签及其对等的 16 进制,之后的一个或多 个字符为非换行符,再之后为结尾标签或其对等的 16 进制。这可能导致一些误 报,具体取决于 Web 应用和 Web 服务器的架构。但这种方式能够确保捕获任 何攻击,甚至远程类似

31、的跨站脚本攻击。对于公众方面,能够加强教育程序,帮 助用户防范可用于帐号劫持和其它形式身份窃取的在线欺诈,如网络钓鱼。 对于质量保证 = 修复跨站脚本漏洞最终要求基于代码的修复。 ”对于开发”和”对于安全操 作”部分所述步骤可为开发人员提供修复这些问题所需的信息。以下步骤概括了 如何对应用程序手动测试跨站脚本。 步骤 1. 在浏览器中打开任意 Web 站点,查找可接受用户输入的位置,如搜索 表单或某些登录页面。在搜索框中输入 test 并发送给 Web 服务器。 步骤 2. 寻找返回类似于 Your search for test did not find any items 或 Invalid login te

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1