WEB应用系统安全规范文档.docx

上传人:11****ws 文档编号:2125275 上传时间:2019-04-29 格式:DOCX 页数:15 大小:110.91KB
下载 相关 举报
WEB应用系统安全规范文档.docx_第1页
第1页 / 共15页
WEB应用系统安全规范文档.docx_第2页
第2页 / 共15页
WEB应用系统安全规范文档.docx_第3页
第3页 / 共15页
WEB应用系统安全规范文档.docx_第4页
第4页 / 共15页
WEB应用系统安全规范文档.docx_第5页
第5页 / 共15页
点击查看更多>>
资源描述

1、WEB 应用系统安全规范目 录WEB应用系统安全规范 .11 概述 .41.1 目的 .41.2 适用范围 .42 范围 .43 名词解释 .44 WEB开发安全规范 .54.1 WEB 应用程序体系结构和安全 .54.2 WEB 安全编码规范 .74.2.1 区分公共区域和受限区域 .74.2.2 对身份验证 cookie 的内容进行加密 .74.2.3 限制会话寿命 .74.2.4 使用 SSL 保护会话身份验证 Cookie .74.2.5 确保用户没有绕过检查 .74.2.6 验证从客户端发送的所有数据 .84.2.7 不要向客户端泄漏信息 .84.2.8 记录详细的错误信息 .84.

2、2.9 捕捉异常 .84.2.10 不要信任 HTTP 头信息 .84.2.11 不要使用 HTTP-GET 协议传递敏感数据 .84.2.12 不要在永久性 cookie 中存储敏感数据 .84.2.13 对数据进行加密或确保通信通道的安全 .94.2.14 SQL 语句的参数应以变量形式传入 .94.2.15 页面中的非源代码内容应经过 URI 编码 .94.2.16 页面中拼装的脚本应校验元素来源的合法性 .94.2.17 页面请求处理应校验参数的最大长度 .94.2.18 登录失败信息错误提示应一致 .104.2.19 避免页面上传任意扩展名的文件 .104.2.20 避免接受页面中的

3、主机磁盘路径信息 .104.2.21 第三方产品的合法性 .105 系统部署安全规范 .105.1 部署架构和安全 .105.1.1 网络基础结构组件 .115.1.2 部署拓扑结构 .125.2 部署操作安全规范 .125.2.1 确保管理界面的安全 .125.2.2 确保配置存储的安全 .125.2.3 单独分配管理特权 .125.2.4 使用最少特权进程和服务帐户 .125.2.5 尽量避免存储机密 .135.2.6 不要在代码中存储机密 .135.2.7 不要以纯文本形式存储数据库连接、密码或密钥 .135.2.8 限制主机上 WEB 系统启动用户的权限 .135.2.9 隐藏后台调试

4、信息 .135.2.10 密码加密存储 .135.2.11 隐藏重要配置参数信息 .145.2.12 隐藏日志文件 .145.2.13 禁用 WebDAV,或者禁止不需要的 HTTP 方法 .145.2.14 保证管理平台、测试账号口令强度 .145.2.15 定期核查文件上传路径、日志路径中是否存在木马 .145.2.16 及时删除应用系统临时文件 .145.2.17 重要系统隔离 .146 安全审计 .156.1 审核并记录跨应用层的访问 .156.2 考虑标识流 .156.3 记录关键事件 .156.4 确保日志文件的安全 .156.5 定期备份和分析日志文件 .167 规范更新机制 .

5、168 规范的执行 .169 参考资料 .171 概述1.1 目的为规范我司 Java Web 应用编码和部署的安全控制和管理,特制定本规范,并作为安全检查及考核的参考依据。1.2 适用范围本规范适用于我司所有在线 Java 业务系统、测试系统的 WEB 应用。本规范可作为其他非 WEB 应用的编码和部署安全办法参考。2 范围本规范中列出的是常见安全措施和高风险的漏洞,在系统开发与系统部署的过程中,对本规范未能尽述的必要安全措施,仍应予以采用。本规范每年复审一次,其它时候也可以根据需要进行修订并发布。 本规范的解释权和修改权归属信息技术部。3 名词解释验证:通讯实体(例如,客户端和服务器 )彼

6、此验证,以经过访问授权的特定标识为依据。资源的访问控制:资源的交互仅限于某些用户或程序的集合,其目的是对完整性,保密性或可用性实施强制约束。 数据完整性:检验信息是否被第三方(非信息源的其它实体) 修改。例如,处于开放网络环境中的数据接收方必须能够检测并丢弃那些在传递过程中被修改过的消息。 机密性或数据隐私:确保信息仅对经过访问授权的用户可用。 不可否认:对用户进行检验,让他无法否认自己进行过的活动。 审核:捕获一个安全相关事件的防篡改记录,目的是评估安全策略和机制的有效性。 4 Web 开发安全规范4.1 Web 应用程序体系结构和安全浏览器防火墙W e b应用程序W e b服务器数据库应用

7、程序应用程序服务器数据库服务器验证用户保护敏感数据防止会话劫持和C o o k i e 回复攻击防止参数操作验证输入授权用户提供安全配置异常处理验证授权上游标志审计 、 记录活动和事务对敏感数据进行加密和哈希处理HTTP 是无国界的,这意味着跟踪每位用户的会话状态将成为应用程序的责任。应用程序必须能够通过某种形式的身份验证来识别用户。由于所有后续授权决策都要基于用户的标识,因此,身份验证过程必须是安全的,同样必须很好地保护用于跟踪已验证用户的会话处理机制。设计安全的身份验证和会话管理机制仅仅是 Web 应用程序设计人员和开发人员所面临的众多问题中的两个方面。由于输入和输出数据要在公共网络上进行

8、传输,因此还会存在其他挑战。防止参数操作和敏感数据泄漏也是另外一些重要问题。Web 应用程序安全设计是根据应用程序漏洞类别进行组织的。实际经验表明,如果这些领域的设计存在薄弱环节,将会导致安全漏洞。下表列出了漏洞的类别,每个类别都突出显示了由于设计不当可能会导致的潜在问题。漏洞类别 由于设计不当而引起的潜在问题输入验证 嵌入到查询字符串、表单字段、cookie 和 HTTP 头中的恶意字符串的攻击。这些攻击包括命令执行、跨站点脚本(XSS)、SQL 注入和缓冲区溢出攻击。身份验证 标识欺骗、密码破解、特权提升和未经授权的访问。授权 访问保密数据或受限数据、篡改数据以及执行未经授权的操作。配置管

9、理 对管理界面进行未经授权的访问、具有更新配置数据的能力以及对用户帐户和帐户配置文件进行未经授权的访问。敏感数据 泄露保密信息以及篡改数据。会话管理 捕捉会话标识符,从而导致会话劫持及标识欺骗。加密 访问保密数据或帐户凭据,或二者均能访问。参数操作 路径遍历攻击、命令执行以及绕过访问控制机制,从而导致信息泄漏、特权提升和拒绝服务。异常管理 拒绝服务和敏感的系统级详细信息的泄漏。审核和记录 不能发现入侵迹象、不能验证用户操作,以及在诊断问题时出现困难。针对上述漏洞的应用程序设计指南如下表:类别 规范指南输入验证 不要信任输入;应考虑集中式输入验证。不要依赖于客户端验证。注意标准化问题。限制、拒绝

10、和净化输入。验证类型、长度、格式和范围。身份验证 将站点分割为匿名区域、标识区域和通过身份验证的区域。使用强密码。支持密码有效期和帐户禁用。不要存储凭据(应使用带有 salt 的单向哈希)。加密通信通道,以保护身份验证令牌。仅通过 HTTPS 连接传递表单身份验证 cookie。授权 使用最少特权帐户。考虑授权粒度。实施分别授权。限制用户访问系统级资源。配置管理 使用最少特权进程和服务帐户。不要以纯文本形式存储凭据。在管理界面上使用强身份验证和授权。不要使用 LSA。远程管理时要确保通信通道的安全。避免在 Web 空间中存储敏感数据。敏感数据 避免存储机密。对网络上传输的敏感数据进行加密。确保

11、通信通道的安全。对敏感数据存储提供强访问控制。不要在永久性 cookie 中存储敏感数据。不要使用 HTTP-GET 协议传递敏感数据。会话管理 限制会话寿命。确保通道的安全。对身份验证 cookie 的内容进行加密。保护会话状态,以防止未经授权的访问。加密 不要自创加密算法。使用可靠并经过测试的平台功能。将未加密的数据存储在算法附近。使用正确的算法和密钥大小。避免密钥管理(使用 DPAPI)。定期回收密钥。在受限区域存储密钥。参数操作 对敏感的 cookie 状态加密。不要信任客户端可以操作的字段(如查询字符串、表单字段、cookie 或 HTTP 头)。验证从客户端发送的所有数据。异常管理

12、 使用结构化的异常处理机制。不要泄漏敏感的应用程序实施细节。不要记录保密数据,如密码。考虑使用集中式的异常管理框架。审核和记录 识别怀有恶意的行为。了解好的数据流应该是什么样子。在所有应用层中审核和记录活动。确保日志文件访问的安全。定期备份和分析日志文件。4.2 Web 安全编码规范4.2.1 区分公共区域和受限区域站点的公共区域允许任何用户进行匿名访问。受限区域只能接受特定用户的访问,而且用户必须通过站点的身份验证。考虑一个典型的零售网站。您可以匿名浏览产品分类。当您向购物车中添加物品时,应用程序将使用会话标识符验证您的身份。最后,当您下订单时,即可执行安全的交易。这需要您进行登录,以便通过

13、 SSL 验证交易。将站点分割为公共访问区域和受限访问区域,可以在该站点的不同区域使用不同的身份验证和授权规则,从而限制对 SSL 的使用。使用 SSL 会导致性能下降,为了避免不必要的系统开销,在设计站点时,应该在要求验证访问的区域限制使用 SSL。4.2.2 对身份验证 cookie 的内容进行加密即使使用 SSL,也要对 cookie 内容进行加密。如果攻击者试图利用 XSS 攻击窃取 cookie,这种方法可以防止攻击者查看和修改该 cookie。在这种情况下,攻击者仍然可以使用 cookie 访问应用程序,但只有当 cookie 有效时,才能访问成功。4.2.3 限制会话寿命缩短会话

14、寿命可以降低会话劫持和重复攻击的风险。会话寿命越短,攻击者捕获会话 cookie 并利用它访问应用程序的时间越有限。4.2.4 使用 SSL 保护会话身份验证 Cookie不要通过 HTTP 连接传递身份验证 cookie。在授权 cookie 内设置安全的 cookie 属性,以便指示浏览器只通过 HTTPS 连接向服务器传回 cookie。4.2.5 确保用户没有绕过检查确保用户没有通过操作参数而绕过检查。最终用户可以通过浏览器地址文本框操作 URL 参数。例如,URL 地址 http:/www./sessionId=10 包含一个值 10,通过将该值更改为其他随机数字,可以得到不同的输出

15、。应确保在服务器端代码中执行上述检查,而不是在客户端的 JavaScript 中检查,因为可以在浏览器中禁用 JavaScript。4.2.6 验证从客户端发送的所有数据限制可接受用户输入的字段,并对来自客户端的所有值进行修改和验证。如果表单字段中包含预定义值,用户可以更改这些值,并将其传回服务器,以得到不同的结果。只接受已知的有益数据。例如,如果输入字段面向一个州,那么只有与该州邮政编码匹配的输入才能被接受。4.2.7 不要向客户端泄漏信息发生故障时,不要暴露将会导致信息泄漏的消息。例如,不要暴露包括函数名以及调试内部版本时出问题的行数(该操作不应在生产服务器上进行)的堆栈跟踪详细信息。应向

16、客户端返回一般性错误消息。4.2.8 记录详细的错误信息向错误日志发送详细的错误消息。应该向服务或应用程序的客户发送最少量的信息,如一般性错误消息和自定义错误日志 ID,随后可以将这些信息映射到事件日志中的详细消息。确保没有记录密码或其他敏感数据。4.2.9 捕捉异常使用结构化异常处理机制,并捕捉异常现象。这样做可以避免将应用程序置于不协调的状态,这种状态可能会导致信息泄漏。它还有助于保护应用程序免受拒绝服务攻击。确定如何在应用程序内部广播异常现象,并着重考虑在应用程序的边界会发生什么事情。4.2.10 不要信任 HTTP 头信息HTTP 头在 HTTP 请求和响应开始时发送。应确保 Web

17、应用程序的任何安全决策都不是基于 HTTP 头中包含的信息,因为攻击者很容易操作 HTTP 头。例如,HTTP 头中的“referer”字段包含发出请求的网页的 URL。不要基于“referer”字段值作出任何安全决策,以检查发出请求的页面是否由该 Web 应用程序生成,因为该字段很容易伪造。4.2.11 不要使用 HTTP-GET 协议传递敏感数据应避免使用 HTTP-GET 协议存储敏感数据,因为该协议使用查询字符串传递数据。使用查询字符串不能确保敏感数据的安全性,因为查询字符串经常被服务器记录下来。4.2.12 不要在永久性 cookie 中存储敏感数据避免在永久性 cookie 中存储

18、敏感数据。如果存储的是纯文本数据,最终用户能够看到并修改该数据。如果对其加密,必须考虑密钥管理。例如,如果用于加密 cookie 中的数据的密钥已过期且已被回收,则新密钥不能对客户端通过浏览器传递的永久性 cookie 进行解密。4.2.13 对数据进行加密或确保通信通道的安全如果在网络上向客户端发送敏感数据,应对数据进行加密或确保通信通道的安全。通常的做法是在客户端与 Web 服务器之间使用 SSL。服务器间的通信通常使用 IPSec。要确保通过多重中间件传输的敏感数据的安全性,如 Web 服务简单对象访问协议 (SOAP) 消息,应使用消息级加密。4.2.14 SQL 语句的参数应以变量形

19、式传入(一)在对数据库进行查询与各类操作时,SQL 语句中的参数应以变量形式传输给服务器,不应直接将参数的值拼接到 SQL 语句的文本中。 (二)参数的类型包括所有数据类型,而不仅是字符串类型。 (三)参数值的来源包括但不限于:用户输入的数据、从数据库中读出的数据、从配 置文件中读出的数据、从外部系统中获得的数据、其它程序逻辑计算得出的数 据,等等。 (四)SQL 语句的执行位置包括但不限于:代码中的 SQL 语句,数据库的存储过程、触发器、定时器等。 (五)应用程序在处理用户非法 URL 请求,触发后台应用程序的 SQL 错误时,应返回 处理后的错误页面提示, 禁止直接抛出数据库 SQL 错

20、误, 如出现 ORA-xxx 等等。4.2.15 页面中的非源代码内容应经过 URI 编码(一)页面中的非源代码内容,应该以 URI 编码后的字符出现,避免特殊字符直接出现在页面中。 (二)内容的来源包括但不限于:在服务器端由程序生成的页面内容、在浏览器端由脚本生成的页面内容(如:javascript 中的 document.write 函数) 。 (三)页面中的隐藏内容、页面格式控制等,也应受本条约束。 4.2.16 页面中拼装的脚本应校验元素来源的合法性(一)在浏览器端拼装并运行(如:利用 javascript 的 eval 函数执行)的脚本,应 校验拼装元素的来源合法性,确定其中没有危害

21、性的内容。 (二)校验的范围包括但不限于:变量名元素应符合标识符的规则、整型元素只包含 数字、元素中不包含特殊字符。 4.2.17 页面请求处理应校验参数的最大长度(一)WEB 服务器在接受页面请求时,应校验参数的最大长度,截断超出最大长度的范围。4.2.18 登录失败信息错误提示应一致(一)WEB 服务器在接受用户登录请求时,不应区分登录失败的提示信息(如:用户名不存在、密码错误、密码已过期等) ,应采用统一的失败提示信息(如:错误 的用户名或密码) 。 4.2.19 避免页面上传任意扩展名的文件(一)WEB 服务器在接受页面上传文件时,应对文件名进行过滤,仅接受指定范围的文件(如:图片,

22、.zip 文件等) ,同时,要修改上传后的文件名,不应接受可能存在危险的文件(如:.jsp, .sh, .war, .jar 文件等) 。 (二)如果出于业务的需要(如:网盘等)必须接受任意扩展名的文件,则应自动修改上传文件的扩展名,并注意采用统一的无风险的扩展名命名规则。 4.2.20 避免接受页面中的主机磁盘路径信息(一)WEB 服务器接受的页面请求中的任何内容,不得作为主机磁盘路径(包括相对路径)处理,尤其不得在程序中提取磁盘上的目录、文件的内容传送到页面。 4.2.21 第三方产品的合法性(一)应选择合法的第三方产品,在使用第三方产品前,需要进行安全的评估和版本筛选。5 系统部署安全规

23、范5.1 部署架构和安全下图显示了需在程序设计阶段考虑的几个程序部署问题。应用程序安全性主机安全性本地应用程序层远程应用程序层部署拓扑路由器防火墙网络基础结构安全交换机安全策略和步骤在应用程序设计阶段,应考虑我司安全策略和程序,以及部署应用程序的基础结构。通常,目标环境是固定不变的,应用程序的设计必须要反映这些限制条件。有时需要折衷考虑设计方案,例如,由于存在协议和端口限制,或是特定部署拓扑结构的要求。要在设计初期确定存在哪些限制条件,以避免日后在开发过程中出现意外;另外,应邀请网络和基础结构工作组的成员参与此过程。5.1.1 网络基础结构组件确保您了解目标环境提供的网络结构,并了解网络的基本

24、安全要求,如筛选规则、端口限制、支持的协议等等。确定防火墙和防火墙策略可能会如何影响应用程序的设计和部署。在面向 Internet 的应用程序和内部网络之间可能存在防火墙将其隔开。也许还存在用于保护数据库的其他防火墙。这些防火墙影响了可用的通信端口,因此会影响 Web 服务器到远程应用程序和数据库服务器的身份验证选项。例如,Windows 身份验证需要附加端口。在设计阶段,需要考虑允许哪些协议、端口和服务从外围网络中的 Web 服务器访问内部资源。还应确定应用程序设计所需的协议和端口,并分析打开新端口或使用新协议会带来哪些潜在威胁。交流并记录所有有关网络和应用层安全的设想,以及哪些组件将处理哪

25、些问题。这样,当开发人员和网络管理人员都认为对方会解决安全问题时,可以防止安全控制失败。注意网络为应用程序提供的安全防范措施。设想如果更改网络设置,可能会带来哪些安全隐患。如果实现特定的网络结构更改,将会出现多少安全漏洞?5.1.2 部署拓扑结构应用程序的部署拓扑结构和是否具有远程应用层是设计阶段必须考虑的关键问题。如果具有远程应用层,需要考虑怎样保护服务器之间的网络以减少网络窃听威胁,以及怎样保护敏感数据的保密性和完整性。此外,还要考虑标识符流,并确定在应用程序连接到远程服务器时将用于网络身份验证的帐户。一种常见方法是使用最小特权进程帐户,并在远程服务器上创建一个具有相同密码的帐户副本(镜像

26、) 。另一种方法是使用域进程帐户,此类帐户管理方便,但会带来更大的安全问题,因为很难限制该帐户在网络上的使用。未建立信任关系的介入防火墙和单独域使应用本地帐户成为唯一的选择。5.2 部署操作安全规范5.2.1 确保管理界面的安全配置管理功能只能由经过授权的操作员和管理员访问,这一点是非常重要的。关键一点是要在管理界面上实施强身份验证,如使用证书。如果有可能,限制或避免使用远程管理,并要求管理员在本地登录。如果需要支持远程管理,应使用加密通道,如 SSL 或 VPN 技术,因为通过管理界面传递的数据是敏感数据。此外,还要考虑使用 IPSec 策略限制对内部网络计算机的远程管理,以进一步降低风险。

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 实用文档资料库 > 策划方案

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。