WEB应用系统安全规范

WEB应用系统安全规范
WEB应用系统安全规范

WEB应用系统安全规范

目录

WEB应用系统安全规范 (1)

1概述 (2)

1.1目的 (2)

1.2适用范围 (3)

2范围 (3)

3名词解释 (3)

4WEB开发安全规范 (4)

4.1W EB应用程序体系结构和安全 (4)

4.2W EB安全编码规范 (6)

4.2.1区分公共区域和受限区域 (6)

4.2.2对身份验证cookie 的内容进行加密 (6)

4.2.3限制会话寿命 (6)

4.2.4使用SSL 保护会话身份验证Cookie (6)

4.2.5确保用户没有绕过检查 (6)

4.2.6验证从客户端发送的所有数据 (7)

4.2.7不要向客户端泄漏信息 (7)

4.2.8记录详细的错误信息 (7)

4.2.9捕捉异常 (7)

4.2.10不要信任HTTP 头信息 (7)

4.2.11不要使用HTTP-GET 协议传递敏感数据 (7)

4.2.12不要在永久性cookie 中存储敏感数据 (7)

4.2.13对数据进行加密或确保通信通道的安全 (8)

4.2.14SQL 语句的参数应以变量形式传入 (8)

4.2.15页面中的非源代码内容应经过URI 编码 (8)

4.2.16页面中拼装的脚本应校验元素来源的合法性 (8)

4.2.17页面请求处理应校验参数的最大长度 (8)

4.2.18登录失败信息错误提示应一致 (9)

4.2.19避免页面上传任意扩展名的文件 (9)

4.2.20避免接受页面中的主机磁盘路径信息 (9)

4.2.21第三方产品的合法性 (9)

5系统部署安全规范 (9)

5.1部署架构和安全 (9)

5.1.1网络基础结构组件 (10)

5.1.2部署拓扑结构 (11)

5.2部署操作安全规范 (11)

5.2.1确保管理界面的安全 (11)

5.2.2确保配置存储的安全 (11)

5.2.3单独分配管理特权 (11)

5.2.4使用最少特权进程和服务帐户 (11)

5.2.5尽量避免存储机密 (12)

5.2.6不要在代码中存储机密 (12)

5.2.7不要以纯文本形式存储数据库连接、密码或密钥 (12)

5.2.8限制主机上WEB 系统启动用户的权限 (12)

5.2.9隐藏后台调试信息 (12)

5.2.10密码加密存储 (12)

5.2.11隐藏重要配置参数信息 (13)

5.2.12隐藏日志文件 (13)

5.2.13禁用WebDAV,或者禁止不需要的HTTP 方法 (13)

5.2.14保证管理平台、测试账号口令强度 (13)

5.2.15定期核查文件上传路径、日志路径中是否存在木马 (13)

5.2.16及时删除应用系统临时文件 (13)

5.2.17重要系统隔离 (13)

6安全审计 (14)

6.1审核并记录跨应用层的访问 (14)

6.2考虑标识流 (14)

6.3记录关键事件 (14)

6.4确保日志文件的安全 (14)

6.5定期备份和分析日志文件 (15)

7规范更新机制 (15)

8规范的执行 (15)

9参考资料 (16)

1概述

1.1目的

为规范我司Java Web应用编码和部署的安全控制和管理,特制定本规范,并作为安全

检查及考核的参考依据。

1.2适用范围

本规范适用于我司所有在线Java业务系统、测试系统的WEB应用。

本规范可作为其他非WEB应用的编码和部署安全办法参考。

2范围

本规范中列出的是常见安全措施和高风险的漏洞,在系统开发与系统部署的过程中,对本规范未能尽述的必要安全措施,仍应予以采用。

本规范每年复审一次,其它时候也可以根据需要进行修订并发布。本规范的解释权和修改权归属信息技术部。

3名词解释

验证:通讯实体(例如,客户端和服务器)彼此验证,以经过访问授权的特定标识为依据。

资源的访问控制:资源的交互仅限于某些用户或程序的集合,其目的是对完整性,保密性或可用性实施强制约束。

数据完整性:检验信息是否被第三方(非信息源的其它实体)修改。例如,处于开放网络环境中的数据接收方必须能够检测并丢弃那些在传递过程中被修改过的消息。

机密性或数据隐私:确保信息仅对经过访问授权的用户可用。

不可否认:对用户进行检验,让他无法否认自己进行过的活动。

审核:捕获一个安全相关事件的防篡改记录,目的是评估安全策略和机制的有效性。

4Web开发安全规范

4.1Web应用程序体系结构和安全

HTTP 是无国界的,这意味着跟踪每位用户的会话状态将成为应用程序的责任。应用程序必须能够通过某种形式的身份验证来识别用户。由于所有后续授权决策都要基于用户的标识,因此,身份验证过程必须是安全的,同样必须很好地保护用于跟踪已验证用户的会话处理机制。设计安全的身份验证和会话管理机制仅仅是Web 应用程序设计人员和开发人员所面临的众多问题中的两个方面。由于输入和输出数据要在公共网络上进行传输,因此还会存在其他挑战。防止参数操作和敏感数据泄漏也是另外一些重要问题。

Web应用程序安全设计是根据应用程序漏洞类别进行组织的。实际经验表明,如果这些领域的设计存在薄弱环节,将会导致安全漏洞。下表列出了漏洞的类别,每个类别都突出显示了由于设计不当可能会导致的潜在问题。

针对上述漏洞的应用程序设计指南如下表:

4.2We b安全编码规范

4.2.1区分公共区域和受限区域

站点的公共区域允许任何用户进行匿名访问。受限区域只能接受特定用户的访问,而且用户必须通过站点的身份验证。考虑一个典型的零售网站。您可以匿名浏览产品分类。当您向购物车中添加物品时,应用程序将使用会话标识符验证您的身份。最后,当您下订单时,即可执行安全的交易。这需要您进行登录,以便通过SSL 验证交易。

将站点分割为公共访问区域和受限访问区域,可以在该站点的不同区域使用不同的身份验证和授权规则,从而限制对SSL 的使用。使用SSL 会导致性能下降,为了避免不必要的系统开销,在设计站点时,应该在要求验证访问的区域限制使用SSL。

4.2.2对身份验证cookie 的内容进行加密

即使使用SSL,也要对cookie 内容进行加密。如果攻击者试图利用XSS 攻击窃取cookie,这种方法可以防止攻击者查看和修改该cookie。在这种情况下,攻击者仍然可以使用cookie 访问应用程序,但只有当cookie 有效时,才能访问成功。

4.2.3限制会话寿命

缩短会话寿命可以降低会话劫持和重复攻击的风险。会话寿命越短,攻击者捕获会话cookie 并利用它访问应用程序的时间越有限。

4.2.4使用SSL 保护会话身份验证Cookie

不要通过HTTP 连接传递身份验证cookie。在授权cookie 内设置安全的cookie 属性,以便指示浏览器只通过HTTPS 连接向服务器传回cookie。

4.2.5确保用户没有绕过检查

确保用户没有通过操作参数而绕过检查。最终用户可以通过浏览器地址文本框操作URL 参数。例如,URL 地址http://www.//sessionId=10 包含一个值10,通过将该值更改为其他随机数字,可以得到不同的输出。应确保在服务器端代码中执行上述检查,而不是在客户端的JavaScript 中检查,因为可以在浏览器中禁用JavaScript。

4.2.6验证从客户端发送的所有数据

限制可接受用户输入的字段,并对来自客户端的所有值进行修改和验证。如果表单字段中包含预定义值,用户可以更改这些值,并将其传回服务器,以得到不同的结果。只接受已知的有益数据。例如,如果输入字段面向一个州,那么只有与该州邮政编码匹配的输入才能被接受。

4.2.7不要向客户端泄漏信息

发生故障时,不要暴露将会导致信息泄漏的消息。例如,不要暴露包括函数名以及调试内部版本时出问题的行数(该操作不应在生产服务器上进行)的堆栈跟踪详细信息。应向客户端返回一般性错误消息。

4.2.8记录详细的错误信息

向错误日志发送详细的错误消息。应该向服务或应用程序的客户发送最少量的信息,如一般性错误消息和自定义错误日志ID,随后可以将这些信息映射到事件日志中的详细消息。确保没有记录密码或其他敏感数据。

4.2.9捕捉异常

使用结构化异常处理机制,并捕捉异常现象。这样做可以避免将应用程序置于不协调的状态,这种状态可能会导致信息泄漏。它还有助于保护应用程序免受拒绝服务攻击。确定如何在应用程序内部广播异常现象,并着重考虑在应用程序的边界会发生什么事情。

4.2.10不要信任HTTP 头信息

HTTP 头在HTTP 请求和响应开始时发送。应确保Web应用程序的任何安全决策都不是基于HTTP 头中包含的信息,因为攻击者很容易操作HTTP 头。例如,HTTP 头中的“referer”字段包含发出请求的网页的URL。不要基于“referer”字段值作出任何安全决策,以检查发出请求的页面是否由该Web 应用程序生成,因为该字段很容易伪造。

4.2.11不要使用HTTP-GET 协议传递敏感数据

应避免使用HTTP-GET 协议存储敏感数据,因为该协议使用查询字符串传递数据。使用查询字符串不能确保敏感数据的安全性,因为查询字符串经常被服务器记录下来。

4.2.12不要在永久性cookie 中存储敏感数据

避免在永久性cookie 中存储敏感数据。如果存储的是纯文本数据,最终用户能够看到并修改该数据。如果对其加密,必须考虑密钥管理。例如,如果用于加密cookie 中的数据

的密钥已过期且已被回收,则新密钥不能对客户端通过浏览器传递的永久性cookie 进行解密。

4.2.13对数据进行加密或确保通信通道的安全

如果在网络上向客户端发送敏感数据,应对数据进行加密或确保通信通道的安全。通常的做法是在客户端与Web 服务器之间使用SSL。服务器间的通信通常使用IPSec。要确保通过多重中间件传输的敏感数据的安全性,如Web 服务简单对象访问协议(SOAP) 消息,应使用消息级加密。

4.2.14SQL 语句的参数应以变量形式传入

(一)在对数据库进行查询与各类操作时,SQL 语句中的参数应以变量形式传输给服务器,不应直接将参数的值拼接到SQL 语句的文本中。

(二)参数的类型包括所有数据类型,而不仅是字符串类型。

(三)参数值的来源包括但不限于:用户输入的数据、从数据库中读出的数据、从配置文件中读出的数据、从外部系统中获得的数据、其它程序逻辑计算得出的数据,等等。

(四)SQL语句的执行位置包括但不限于:代码中的SQL 语句,数据库的存储过程、触发器、定时器等。

(五)应用程序在处理用户非法URL 请求,触发后台应用程序的SQL 错误时,应返回处理后的错误页面提示,禁止直接抛出数据库SQL 错误,如出现ORA-xxx 等等。

4.2.15页面中的非源代码内容应经过URI 编码

(一)页面中的非源代码内容,应该以URI 编码后的字符出现,避免特殊字符直接出现在页面中。

(二)内容的来源包括但不限于:在服务器端由程序生成的页面内容、在浏览器端由脚本生成的页面内容(如:javascript 中的document.write 函数)。

(三)页面中的隐藏内容、页面格式控制等,也应受本条约束。

4.2.16页面中拼装的脚本应校验元素来源的合法性

(一)在浏览器端拼装并运行(如:利用javascript 的eval 函数执行)的脚本,应校验拼装元素的来源合法性,确定其中没有危害性的内容。

(二)校验的范围包括但不限于:变量名元素应符合标识符的规则、整型元素只包含数字、元素中不包含特殊字符。

4.2.17页面请求处理应校验参数的最大长度

(一)WEB 服务器在接受页面请求时,应校验参数的最大长度,截断超出最大长度的

范围。

4.2.18登录失败信息错误提示应一致

(一)WEB 服务器在接受用户登录请求时,不应区分登录失败的提示信息(如:用户名不存在、密码错误、密码已过期等),应采用统一的失败提示信息(如:错误的用户名或密码)。

4.2.19避免页面上传任意扩展名的文件

(一)WEB 服务器在接受页面上传文件时,应对文件名进行过滤,仅接受指定范围的文件(如:图片, .zip 文件等),同时,要修改上传后的文件名,不应接受可能存在危险的文件(如:.jsp, .sh, .war, .jar 文件等)。

(二)如果出于业务的需要(如:网盘等)必须接受任意扩展名的文件,则应自动修改上传文件的扩展名,并注意采用统一的无风险的扩展名命名规则。

4.2.20避免接受页面中的主机磁盘路径信息

(一)WEB 服务器接受的页面请求中的任何内容,不得作为主机磁盘路径(包括相对路径)处理,尤其不得在程序中提取磁盘上的目录、文件的内容传送到页面。

4.2.21第三方产品的合法性

(一)应选择合法的第三方产品,在使用第三方产品前,需要进行安全的评估和版本筛选。

5系统部署安全规范

5.1部署架构和安全

下图显示了需在程序设计阶段考虑的几个程序部署问题。

在应用程序设计阶段,应考虑我司安全策略和程序,以及部署应用程序的基础结构。通常,目标环境是固定不变的,应用程序的设计必须要反映这些限制条件。有时需要折衷考虑设计方案,例如,由于存在协议和端口限制,或是特定部署拓扑结构的要求。要在设计初期确定存在哪些限制条件,以避免日后在开发过程中出现意外;另外,应邀请网络和基础结构工作组的成员参与此过程。

5.1.1网络基础结构组件

确保您了解目标环境提供的网络结构,并了解网络的基本安全要求,如筛选规则、端口限制、支持的协议等等。

确定防火墙和防火墙策略可能会如何影响应用程序的设计和部署。在面向Internet 的应用程序和内部网络之间可能存在防火墙将其隔开。也许还存在用于保护数据库的其他防火墙。这些防火墙影响了可用的通信端口,因此会影响Web 服务器到远程应用程序和数据库服务器的身份验证选项。例如,Windows 身份验证需要附加端口。

在设计阶段,需要考虑允许哪些协议、端口和服务从外围网络中的Web 服务器访问内部资源。还应确定应用程序设计所需的协议和端口,并分析打开新端口或使用新协议会带来哪些潜在威胁。

交流并记录所有有关网络和应用层安全的设想,以及哪些组件将处理哪些问题。这样,当开发人员和网络管理人员都认为对方会解决安全问题时,可以防止安全控制失败。注意网络为应用程序提供的安全防范措施。设想如果更改网络设置,可能会带来哪些安全隐患。如果实现特定的网络结构更改,将会出现多少安全漏洞?

5.1.2部署拓扑结构

应用程序的部署拓扑结构和是否具有远程应用层是设计阶段必须考虑的关键问题。如果具有远程应用层,需要考虑怎样保护服务器之间的网络以减少网络窃听威胁,以及怎样保护敏感数据的保密性和完整性。

此外,还要考虑标识符流,并确定在应用程序连接到远程服务器时将用于网络身份验证的帐户。一种常见方法是使用最小特权进程帐户,并在远程服务器上创建一个具有相同密码的帐户副本(镜像)。另一种方法是使用域进程帐户,此类帐户管理方便,但会带来更大的安全问题,因为很难限制该帐户在网络上的使用。未建立信任关系的介入防火墙和单独域使应用本地帐户成为唯一的选择。

5.2部署操作安全规范

5.2.1确保管理界面的安全

配置管理功能只能由经过授权的操作员和管理员访问,这一点是非常重要的。关键一点是要在管理界面上实施强身份验证,如使用证书。

如果有可能,限制或避免使用远程管理,并要求管理员在本地登录。如果需要支持远程管理,应使用加密通道,如SSL 或VPN 技术,因为通过管理界面传递的数据是敏感数据。此外,还要考虑使用IPSec 策略限制对内部网络计算机的远程管理,以进一步降低风险。

5.2.2确保配置存储的安全

基于文本的配置文件、注册表和数据库是存储应用程序配置数据的常用方法。如有可能,应避免在应用程序的Web 空间使用配置文件,以防止可能出现的服务器配置漏洞导致配置文件被下载。无论使用哪种方法,都应确保配置存储访问的安全,如使用Windows ACL 或数据库权限。还应避免以纯文本形式存储机密,如数据库连接字符串或帐户凭据。通过加密确保这些项目的安全,然后限制对包含加密数据的注册表项、文件或表的访问权限。

5.2.3单独分配管理特权

如果应用程序的配置管理功能所支持的功能性基于管理员角色而变化,则应考虑使用基于角色的授权策略分别为每个角色授权。例如,负责更新站点静态内容的人员不必具有更改客户信贷限额的权限。

5.2.4使用最少特权进程和服务帐户

应用程序配置的一个重要方面是用于运行Web 服务器进程的进程帐户,以及用于访问下游资源和系统的服务帐户。应确保为这些帐户设置最少特权。如果攻击者设法控制一个进

程,则该进程标识对文件系统和其他系统资源应该具有极有限的访问权限,以减少可能造成的危害。

5.2.5尽量避免存储机密

在软件中以完全安全的方式存储机密是不可能的。可以接触到服务器的系统管理员可以访问这些数据。例如,当您所要做的仅仅是验证用户是否知道某个机密时,则没有必要存储该机密。在这种情况下,可以存储代表机密的哈希值,然后使用用户提供的值计算哈希值,以验证该用户是否知道该机密。

5.2.6不要在代码中存储机密

不要在代码中对机密进行硬编码。即使不将源代码暴露在Web 服务器上,但从编译过的可执行文件中仍然可以提取字符串常量。配置漏洞可能会允许攻击者检索可执行文件。

5.2.7不要以纯文本形式存储数据库连接、密码或密钥

避免以纯文本形式存储诸如数据库连接字符串、密码和密钥之类的机密。使用加密,并存储经过加密的字符串。

5.2.8限制主机上WEB 系统启动用户的权限

(一)应将WEB系统的启动用户的权限限制在最小范围内,禁止该用户访问其它不必要的路径(如:/etc/、/root)。

5.2.9隐藏后台调试信息

(一)WEB 系统、数据库等报告的异常信息、调试信息不应该出现在页面上。

5.2.10密码加密存储

(一)WEB 系统中存储的密码应采用一定的加密算法,以密文形式存放。此处所指的密码包括但不限于:

1.配置文件中的主机、网络、数据库、邮箱的密码;

2.数据库中的用户资料密码;

(二)加密算法的选择应根据实际需要,首选不对称加密算法,次选破解难度高的对称加密算法。

5.2.11隐藏重要配置参数信息

(一)对于重要的配置参数信息,应采用必要的隐藏措施,具体技术请遵循《我司敏感参数保护规范》

(二)此处所指的配置参数包括但不限于:

1. 重要的用户名、密码;

2. 重要设备的内网地址(如:数据库、存储设备);

5.2.12隐藏日志文件

(一)不应将日志文件的路径设置在页面可达的位置,用户通过页面应该无法访问到系统产生的日志文件。

5.2.13禁用WebDAV,或者禁止不需要的HTTP 方法

(一)在无特定的需求情况下,应只开放GET, HEAD, POST 等安全的HTTP 方法,禁用PUT, DELETE, OPTIONS 等具有操作性质的HTTP 方法。

5.2.14保证管理平台、测试账号口令强度

(一)WEB系统的管理平台、测试账号的口令应具有足够的强度。具体要求请遵循《我司公司系统帐号口令管理办法》。

5.2.15定期核查文件上传路径、日志路径中是否存在木马

(一)应定期对不可能出现代码的路径进行检查,及时发现与排除可能存在的木马。

(二)需要检查的路径包括但不限于:用户文件上传路径、日志文件路径。

5.2.16及时删除应用系统临时文件

(一)WEB系统中不应该含有不必要的文件。包括但不限于:.CVS 文件夹、.svn 文件夹、临时备份文件等等。

(二)对于WEB页面备份文件,不要以.bak文件存放(如index.jsp.bak 等)

5.2.17重要系统隔离

(一)在部署WEB系统时,应根据实际情况,尽量使重要系统之间互相隔离、重要系统与其它系统之间隔离。

(二)隔离措施包括但不限于:主机分离、数据库分离、网段隔离。

6安全审计

应该审核和记录跨应用层的活动。使用日志,可以检测到踪迹可疑的活动。这通常能较早地发现成熟攻击的迹象,日志还有助于解决抵赖问题,即用户拒绝承认其行为的问题。在证明个人错误行为的法律程序中,可能需要使用日志文件作为证据。通常情况下,如果审核的生成时间恰好是资源访问的时间,并且使用相同的资源访问例程,则审核是最具权威性的。

以下做法可以提高Web 应用程序的安全性:

审核并记录跨应用层的访问

考虑标识流

记录关键事件

确保日志文件的安全

定期备份和分析日志文件

6.1审核并记录跨应用层的访问

审核并记录跨应用层的访问,以便用于认可。可以结合使用应用程序级记录和平台审核功能,如操作系统、Web服务器和数据库审核。

6.2考虑标识流

考虑应用程序如何在多重应用层间传送调用方标识。有两个基本选择。可以使用Kerberos 协议委派,在操作系统级传送调用方标识。这允许您使用操作系统级审核。这种方法的缺点在于它影响了可伸缩性,因为它意味着在中间层可能没有有效的数据库连接池。另外,还可以在应用程序级传送调用方标识,并使用受信任标识访问后端资源。使用此方法时,必须信任中间层,因此存在着潜在的抵赖风险。应在中间层生成审核跟踪,使之能与后端审核跟踪相关联。因此,必须确保服务器时钟是同步的,虽然Microsoft Windows 2000 和Active Directory 提供了此项功能。

6.3记录关键事件

应记录的事件类型包括成功和失败的登录尝试、数据修改、数据检索、网络通信和管理功能,如启用或禁用日志记录。日志应包括事件发生的时间、地点(包括主机名)、当前用户的标识、启动该事件的进程标识以及对该事件的详细描述。

6.4确保日志文件的安全

应使用操作系统访问控制(ACL)确保日志文件的安全,并限制对日志文件的访问。这加大了攻击者篡改日志文件以掩饰其攻击行为的难度。应将有权操作日志文件的个人数量减到最小。只为高度信任的帐户(如管理员)授予访问权限。

6.5定期备份和分析日志文件

如果从不对日志文件进行分析,则记录活动没有任何意义。应定期删除生产服务器上的日志文件。删除频率取决于应用程序的活动级别。设计程序时,应考虑检索日志文件和将其移到脱机服务器进行分析的方式。必须安全地锁定Web 服务器上为此目的打开的所有其他协议和端口。

7规范更新机制

8规范的执行

本规范的执行遵从现有的项目管理办法,在项目管理办法中补充如下表中内容:

9参考资料

WEB安全编程技术规范(V1.0)

1.范围 本规范从应用开发安全管理要求出发,给出了WEB编码安全的具体要求。供浙江公司IT系统内部和厂商使用,适用于省市公司IT系统项目建设WEB工作。 本规范明确定义了JA V A、PHP应用开发中和WEB编码安全相关的技术细节。 与JA V A编码安全相关的内容包括:跨站脚本攻击及解决方法、SQL注入及解决方法、恶意文件执行及解决方法、不安全的直接对象引用及解决方法、跨站请求伪造及解决方法、信息泄露和错误处理不当及解决方法、残缺的认证和会话管理及解决方法、不安全的加密存储及解决方法、不安全的通信及解决方法、限制URL 访问实效解决方法。 与PHP编码安全相关的内容包括:变量滥用及解决方法、文件打开漏洞及解决方法、文件包含漏洞及解决方法、文件上传漏洞及解决方法、命令执行漏洞及解决方法、变量类型缺陷及解决方法、警告及错误信息处理解决方法、PHP与MYSQL 组合的SQL注入解决方法、跨站脚本解决方法。 2.1.规范概述 Web应用程序为结构设计人员、设计人员和开发人员提出一系列复杂的安全问题。最安全、最有能力抵御攻击的Web应用程序是那些应用安全思想构建的应用程序。 在设计初始阶段,应该使用可靠的体系结构和设计方法,同时要结合考虑程序部署以及企业的安全策略。如果不能做到这一点,将导致在现有基础结构上部署应用程序时,要不可避免地危及安全性。 本规范提供一系列安全的体系结构和设计指南,并按照常见的应用程序漏洞类别进行组织。这些指南是Web应用程序安全的重要方面,并且是经常发生错误的领域。

2.实现目标 使用本规范可以实现: 1.确定安全Web应用程序的重要体系结构和设计问题。 2.设计时考虑重要部署问题。 3.制定能增强Web应用程序输入验证的策略。 4.设计安全的身份验证和会话管理机制。 5.选择适当的授权模型。 6.实现有效的帐户管理方法,并保护用户会话。 7.对隐私、认可、防止篡改和身份验证信息进行加密。 8.防止参数操作。 9.设计审核和记录策略。 3.安全编码原则 1.程序只实现你指定的功能 2.永不要信任用户输入,对用户输入数据做有效性检查 3.必须考虑意外情况并进行处理 4.不要试图在发现错误之后继续执行 5.尽可能使用安全函数进行编程 6.小心、认真、细致地编程 4.安全背景知识 本规范主要提供设计应用程序时应该遵循的一些指南和原则。为充分理解本规范内容,请:了解应用程序将会受到的威胁,以确保通过程序设计解决这些问题。解需要考虑的威胁。在程序设计阶段应该考虑到这些威胁。 在应用程序易受攻击的重要环节应用系统的方法。将重点放在程序部署、输入验证、身份验证和授权、加密及数据敏感度、配臵、会话、异常管理以及适当的审核和记录策略上,以确保应用程序具有责任性。

Web安全系统测试要求规范

DKBA DKBA 2355-2009.7 .2cto.红黑联盟收集整理 Web应用安全测试规V1.2 2009年7月5日发布2009年7月5日实施 所有侵权必究 All rights reserved

修订声明Revision declaration 本规拟制与解释部门: 安全解决方案部电信网络与业务安全实验室、软件公司安全TMG、软件公司测试业务管理部 本规的相关系列规或文件: 《Web应用安全开发规》 相关国际规或文件一致性: 《OWASP Testing Guide v3》 《信息安全技术信息安全风险评估指南》 《Information technology Security techniques Management of information and communications technology security》-ISO 13335 替代或作废的其它规或文件: 无 相关规或文件的相互关系: 本规以《Web应用安全开发规》为基础、结合Web应用的特点而制定。

目录Table of Contents 1概述 (7) 1.1背景简介 (7) 1.2适用读者 (7) 1.3适用围 (7) 1.4安全测试在IPD流程中所处的位置 (8) 1.5安全测试与安全风险评估的关系说明 (8) 1.6注意事项 (9) 1.7测试用例级别说明 (9) 2测试过程示意图 (10) 3WEB安全测试规 (11) 3.1自动化W EB漏洞扫描工具测试 (11) 3.1.1AppScan application扫描测试 (12) 3.1.2AppScan Web Service 扫描测试 (13) 3.2服务器信息收集 (13) 3.2.1运行权限测试 (13) 3.2.2Web服务器端口扫描 (14) 3.2.3HTTP方法测试 (14) 3.2.4HTTP PUT方法测试 (15) 3.2.5HTTP DELETE方法测试 (16) 3.2.6HTTP TRACE方法测试 (17) 3.2.7HTTP MOVE方法测试 (17) 3.2.8HTTP COPY方法测试 (18) 3.2.9Web服务器版本信息收集 (18) 3.3文件、目录测试 (20) 3.3.1工具方式的敏感接口遍历 (20) 3.3.2Robots方式的敏感接口查找 (21)

基于WEB的应用系统安全方案

第二章系统安全的需求分析 本章从数据安全和业务逻辑安全两个角度对应用系统的安全进行需求分析,主要包括保密性需求、完整性需求、可用性需求三部分;随后对业务逻辑安全需求进行了分析,包括身份认证、访问控制、交易重复提交控制、异步交易处理、交易数据不可否认性、监控与审计等几个方面;最后还分析了系统中一些其它的安全需求。 2.1 数据安全需求 2.1.1 数据保密性需求 数据保密性要求数据只能由授权实体存取和识别,防止非授权泄露。从目前国内应用的安全案例统计数据来看,数据保密性是最易受到攻击的一个方面,通常表现为客户端发生的数据泄密,包括用户的基本信息、账户信息、登录信息等的泄露。在应用系统中,数据保密性需求通常主要体现在以下几个方面:A.客户端与系统交互时输入的各类密码:包括系统登录密码、转账密码、凭证查询密码、凭证交易密码等必须加密传输及存放,这些密码在应用系统中只能以密文的方式存在,其明文形式能且只能由其合法主体能够识别。 以网银系统为例,在网银系统中,通常存有四种密码:系统登录密码、网银转账密码、柜面交易密码及一次性密码。系统登录密码用来认证当前登录者为指定登录名的合法用户,网银用户的登录密码和网银转账密码由用户在柜面开户时指定,用户在首次登录网银系统时,系统必须强制用户修改初始密码,通常要求长度不得少于六位数,且不能是类似于111111、1234567、9876543等的简单数字序列,系统将进行检查。 网银转账密码是指网银系统为巩固用户资金安全,在涉及资金变动的交易中对用户身份进行了再认证,要求用户输入预设的密码,网银交易密码仅针对个人用户使用,企业用户没有网银交易密码。建立多重密码机制,将登录密码与网银转账密码分开管理,有利于加强密码的安全性。由于用户在使用网银时每次都必须先提供登录密码,故登录密码暴露的机会较多,安全性相对较弱;但登录网银的用户并不是每次都会操作账户资金的,所以专门设定网银转账密码可加强账户

网站WEB应用安全措施要求规范

网站WEB应用安全措施要求规范 1.安全防范措施要求 (1)数据保密性:数据加密主要是防止非授权用户截获并使用该数据,网站中有保密要求的信息只能供经过授权允许的人员,并且以经过允许的方式使用。 (2)数据完整性:使用一种方案来确认同站上的数据在传输过程中没有被篡改,而造成信息完整性破坏的原因可以分为人为的和非人为的两种: 非人为的因素:如通信传输中的干扰噪声,系统硬件或软件的故障等; 人为因素:包括有意的和无意的两种,前者如黑客对计算机的入侵、合法用户越权对网站内数据的处理,后者如操作失误或使用不当。 (3)数据安全性:数据的安全性就是保证数据库不被故意破坏和非法存取:数据的完整性是防止数据库中存在不符合语义的数据,以及防止由于错误信息的输入、输出而造成无效操作和错误结果:并发控制即数据库是一个共享资源,在多个用户程序并行地存取数据库时,就可能会产生多个用户程序通过网站并发地存取同一数据的情况,若不进行并发控制就会使取出和存入的数据不正确,破坏数据库的一致性。 (4)恶意代码防范:通过代码层屏蔽常见恶意攻击行为,防止非法数据提交;如:SQL注入; (5)双因子授权认证:应对同一用户采用两种或两种以上组合的鉴别技术实现用户身份鉴别。 (6)密码复杂度:强制用户首次登录时修改初始口令;口令长度至少为8位,并由数字、大小字母与特殊字符组成。 (7)会话过期与超时:浏览器Cookie过期、无动作过期、强制过期、保持会话等进行限制; (8)安全审计功能:a)审计覆盖到每个用户,对重要的用户行为和重要安全事件进行审计,如:登录、退出、添加、删除、修改或覆盖等;b)审计记录应包括事件的日期和时间、用户、事件类型、事件是否成功及其他与审计相关的信息;

(完整版)web服务器安全标准

Web服务器安全标准 前言和文档控制 此文档是西安石油大学制定发布的有关信息安全政策规定、处理流程、行业标准和指导意见的系列文档之一。该文档应保证至少一年审核一次,以保证其有效性。 在没有得到文档发布者的明确授权下,此文档的全部或部分内容,均不得重制或发布。

目录 1目的 (3) 2范围 (3) 3责任 (3) 4Web服务器安全要求 (3) 4.1总则 (3) 4.2网络安全 (3) 4.3流量过滤 (3) 4.4合规性 (4) 4.5数据保护 (4) 4.6输入和输出管理 (4) 4.7安全代码/应用/插件 (4)

1目的 发布本文档所列标准的目的是为了保护学校网站和相关信息资产。本标准的目标是为了确保: ●按照现有最佳的实践经验,在全校统一部署安全控制措施,以消除或者最低限 度的减少系统漏洞和其他安全隐患。 ●学校能在信息安全的完善方面更方便的有据监管、理解风险和评估改进。 ●所有的院系部门和网站开发人员都能了解相应的安全需求 2范围 所列标准适用于学校所有的web网站服务器,包括:学校内部或第三方建设、采购、部署、修改和维护的。具体为: ●所有仅限内部和面向公共的web服务器 ●所有由外部供应商托管的面向公共的web服务器 ●所有通过学校或者代表学校的web服务器建设、采购、部署、修改和维护的 3责任 以下学校实体具体的信息安全责任 ●学校信息化委员会 ●信息安全部门领导 ●信息安全小组应支撑学校满足信息安全功能和防护的各项要求。 ●学院和部门领导对所在部门的信息安全负有义务和责任。 ●Web服务器用户对其处理的信息负有安全责任。 4Web服务器安全要求 4.1总则 4.1.1基于风险分析的深度信息安全防范手段应被采用,包括: 4.1.1.1安全控件在Web服务器的每一层次上都应部署,以避免过度依赖单一 安全防护手段。 4.1.1.2在所有Web服务器上应部署最基本的安全控制措施,以解决常见风险。 4.1.1.3安全控制措施应该是务实的、易于部署、有效和可以衡量的。 4.1.2在虚拟化环境中,所有能考虑到的安全因素都应当适用于主机系统、虚拟机 管理层和虚拟化管理工具。 4.1.3渗透性测试每年至少执行一次,并且在重要系统架构部署、应用升级或修改 后,都应测试。 4.1.4每季度应执行一次漏洞扫描。 4.2网络安全 4.2.1安全控制措施应涵盖每一个活跃版本的网络协议,包括IPv4和IPv6。 4.2.2Web服务器都应分配相应的静态IP地址,除了需要部署动态域名系统技术以 实现负载均衡的服务器。 4.2.3只使用唯一可信的授权DNS来源,避免受到DNS劫持和攻击。 4.2.4所有的非console口管理员级别的访问应使用高强度加密手段进行加密。 4.3流量过滤 4.3.1只有从Internet到特定的IP地址和授权的公共可用服务、协议和端口的入 站流量是允许的。 4.3.2从Web服务器的非授权出站流量是禁止的。

华为Web应用安全开发规范

DKBA 华为技术有限公司内部技术规范 DKBA 1606-XXXX.X Web应用安全开发规范V1.5 2013年XX月XX日发布2013年XX月XX日实施华为技术有限公司 Huawei Technologies Co., Ltd. 版权所有侵权必究 All rights reserved 修订声明Revision declaration 本规范拟制与解释部门: 网络安全能力中心&电信软件与核心网网络安全工程部 本规范的相关系列规范或文件: 《C&C++语言安全编程规范》《Java语言安全编程规范》相关国际规范或文件一致性: 无 替代或作废的其它规范或文件: 无 相关规范或文件的相互关系:

《产品网络安全红线》和《电信软件与核心网业务部安全能力基线》中的Web安全要求引用了本规范的内容,如果存在冲突,以本规范为准。 规范号主要起草部门专家主要评审部门专家修订情况 DKBA 1606-2007.4 安全解决方案:赵武42873,杨光磊57125,万振华55108 软件公司设计管理部:刘茂征11000,刘高峰63564,何伟祥33428 安全解决方案:刘海军12014,吴宇翔18167,吴海翔57182 接入网:彭东红27279 无线:胡涛46634 核心网:吴桂彬41508,甘嘉栋33229,马进32897,谢秀洪33194,张毅27651,张永锋40582 业软:包宜强56737,丁小龙63583,董鹏越60793,傅鉴杏36918,傅用成30333,龚连阳18753,胡海,胡海华52463,李诚37517,李大锋54630,李战杰21615,刘创文65632,刘飞46266,刘剑51690,栾阳62227,罗仁钧65560,罗湘武06277,马亮,孟咏喜22499,潘海涛27360,孙林46580,王福40317,王锦亮36430,王美玲,王谟磊65558,王玉龙24387,杨娟,张锋43381,张健,张轶57143,邹韬51591 V1.0 何伟祥33428 刘高峰63564,龚连阳00129383,许汝波62966,吴宇翔00120395,王欢00104062,吕晓雨56987 V1.2 增加了Web Service、Ajax和上传和下载相关的安全规范。 何伟祥V1.3 增加了防止会话固定和防止跨站请求伪造的安全规范。 何伟祥V1.4 增加了"规则 3.4.1"的实施指导;删除了"建议 3.4.1";修改了"6 配套CBB介绍"的内容和获取方式。增加了"3.9 DWR" 何伟祥00162822 吴淑荣00197720 魏建雄00222906 谢和坤00197709 李田00042091 孙波00175839 朱双红00051429 王伟00207440 陈伟00141500 V1.5 增加"规则3.3.9、规则 3.6.5、规则 4.7.1、建议 4.7.2、4.8 PHP" 增加"3.8 RESTful Web Service" 修改"规则3.2.2.8、规则 3.2.2.3、规则 3.4.1、规则 4.6.1" 删除"3.2.1口令策略"和"规则3.1.3、规则 3.2.3.8、规则 4.7.1" 附件文档作为对象直接插入主文档 目录Table of Contents 1 概述7 1.1 背景简介7 1.2 技术框架7 1.3 使用对象8

Web应用安全测试规范

Web应用安全测试规范 Web应用安全测试规范V 1、2全文结束》》年7月5日发布全文结束》》年7月5日实施版权所有侵权必究 All rights reserved 修订声明Revision declaration 本规范拟制与解释部门: 安全解决方案部电信网络与业务安全实验室、软件公司安全TMG、软件公司测试业务管理部本规范的相关系列规范或文件: Web应用安全开发规范相关国际规范或文件一致性: OWASP Testing Guide v3 信息安全技术信息安全风险评估指南Information technology Security techniques Management of information and communications technology securityISO13335 替代或作废的其它规范或文件:无相关规范或文件的相互关系: 本规范以Web应用安全开发规范为基础、结合Web应用的特点而制定。 版本号主要起草部门专家主要评审部门专家修订情况 V 1、1 V 1、2 增加 Web Service、上传、下载、控制台等方面的测试规范,更正V 1、1 一些描述不准确的测试项 目录Table of Contents1 概述、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、7 1、 1 背景简介、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、7 1、 2 适用读者、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、、

系统安全配置技术规范-Websphere

系统安全配置技术规范—Websphere

文档说明(一)变更信息 (二)文档审核人

目录 1.适用范围4 2.帐号管理与授权4 2.1............................................................................. 【基本】控制台帐号安全 4 2.2............................................................................. 【基本】帐号的口令安全 4 2.3............................................................. 【基本】为应用用户定义合适的角色 5 2.4................................................................................... 【基本】控制台安全 5 2.5............................................................... 【基本】全局安全性与J AVA2安全 6 3.日志配置要求6 3.1.......................................................................... 【基本】开启应用日志记录 6 4.服务配置要求7 4.1.......................................................................... 【基本】禁止列表显示文件 7 4.2................................................................... 【基本】禁止浏览列表显示目录 7 4.3................................................................................ 【基本】删除示例程序 8 4.4............................................................................. 【基本】控制台超时设置 8

WEB安全编程技术规范

1.范围 本规范从WEB应用开发安全管理要求出发,给出了WEB编码安全的具体要求。 本规范明确定义了JAVA应用开发中和WEB编码安全相关的技术细节。 与JAVA编码安全相关的内容包括:跨站脚本攻击及解决方法、SQL注入及解决方法、恶意文件执行及解决方法、不安全的直接对象引用及解决方法、跨站请求伪造及解决方法、信息泄露和错误处理不当及解决方法、残缺的认证和会话管理及解决方法、不安全的加密存储及解决方法、不安全的通信及解决方法、限制URL访问实效解决方法等。 2.1.规范概述 Web应用程序为架构设计人员、开发人员、测试人员和运维运营人员提出一系列复杂的安全问题,最安全、最有能力抵御攻击的Web应用程序是那些应用安全思想构建的应用程序。 在设计初始阶段,应该使用可靠的体系结构和设计方法,同时要结合考虑程序部署以及企业的安全策略。如果不能做到这一点,将导致在现有基础结构上部署应用程序时,要不可避免地危及安全性。 本规范提供一系列安全的体系结构和设计指南,并按照常见的应用程序漏洞类别进行组织。这些指南是Web应用程序安全的重要方面,并且是经常发生错误的领域。 2.实现目标 使用本规范可以实现: 1.确定安全Web应用程序的重要体系结构和设计问题。 2.设计时考虑重要部署问题。 3.制定能增强Web应用程序输入验证的策略。 4.设计安全的身份验证和会话管理机制。 5.选择适当的授权模型。 6.实现有效的帐户管理方法,并保护用户会话。 7.对隐私认可并防止篡改,和对身份验证信息进行加密。

8.防止参数操作。 9.安全漏洞checklist。 10.设计审核和记录策略。 3.安全编码原则 1.程序只实现你指定的功能。 2.永不要信任用户输入,对用户输入数据做有效性检查。 3.必须考虑意外情况并进行处理。 4.不要试图在发现错误之后继续执行。 5.尽可能使用安全函数进行编程。 6.小心、认真、细致地编程。 4.安全背景知识 本规范主要提供设计应用程序时应该遵循的一些指南和原则。为充分理解本规范内容,请: 了解应用程序将会受到的威胁,以确保通过程序设计解决这些问题。了解需要考虑的威胁,在程序设计阶段应该考虑到这些威胁。 在应用程序易受攻击的重要环节应用系统的方法。将重点放在程序部署、输入验证、身份验证和授权、加密及数据敏感度、配臵、会话、异常管理以及适当的审核和记录策略上,以确保应用程序具有健壮性。 5.JAVA安全编程——OWASP TOP10ANDESAPI 5.1OWASP TOP10 与ESAPI OWASP(开放Web应用安全项目-OpenWebApplicationSecurityProject)是一个开放社群、非营利性组织,目前全球有82个分会近万名会员,其主要目是研议协助解决Web 软体安全之准则、工具与技术,长期致力于协助政府或企业并改善网页应用程式与网页服务的安全性。

WEB类应用系统安全防护技术要求

WEB类应用系统安全防护技术要求 Technical Specification of Security for Web Applications 版本号: 1.0.0 中国移动通信有限网络部

目录 前言 (1) 1适用范围 (2) 2引用标准与依据 (2) 3相关术语与缩略语 (2) 3.1术语 (2) 3.1.1注入漏洞 (2) 3.1.2SQL注入攻击 (3) 3.1.3跨站漏洞 (3) 3.1.4跨站攻击 (3) 3.1.5非法上传 (3) 3.1.6缓冲区溢出 (3) 3.1.7非法输入 (3) 3.1.8网站挂马 (3) 3.1.9拒绝服务攻击 (3) 3.1.10跨站请求伪造 (4) 3.1.11目录遍历攻击 (4) 3.2缩略语 (4) 4综述 (4) 5WEB类应用系统基本架构 (5) 5.1业务逻辑结构 (5) 5.2网络结构 (5) 6WEB类应用风险分析 (6) 6.1主要风险分析 (6) 6.2脆弱性分析 (7) 6.2.1物理 (7) 6.2.2网络 (7) 6.2.3设备 (7) 6.2.4应用 (8) 6.2.5内容 (10) 6.2.6管理 (10) 6.3威胁分析 (10) 6.3.1物理 (10) 6.3.2网络 (10) 6.3.3设备 (11) 6.3.4应用 (11) 6.3.5内容 (13) 7WEB类应用系统的安全防护需求 (13) 7.1物理安全需求 (13) 7.2分区防护需求 (13) 7.2.1安全域划分要求 (13) 7.2.2边界整合及域间互联安全要求 (14) 7.3WEB类应用系统自身安全要求 (16) 7.3.1操作系统安全要求 (16) 7.3.2中间件安全要求 (16) 7.3.3数据库安全要求 (17) 7.3.4应用软件自身安全要求 (17) 7.4专用安全设备部署需求 (20)

WEB应用系统安全规范文档

目录 WEB应用系统安全规范................................................. 错误!未定义书签。1概述............................................................ 错误!未定义书签。 目的 .................................................................... 错误!未定义书签。 适用范围 ................................................................ 错误!未定义书签。2范围............................................................ 错误!未定义书签。3名词解释........................................................ 错误!未定义书签。4WEB开发安全规范................................................. 错误!未定义书签。 W EB应用程序体系结构和安全................................................ 错误!未定义书签。 W EB安全编码规范.......................................................... 错误!未定义书签。 区分公共区域和受限区域......................................... 错误!未定义书签。 对身份验证 cookie 的内容进行加密............................... 错误!未定义书签。 限制会话寿命 .................................................. 错误!未定义书签。 使用 SSL 保护会话身份验证 Cookie ............................... 错误!未定义书签。 确保用户没有绕过检查........................................... 错误!未定义书签。 验证从客户端发送的所有数据..................................... 错误!未定义书签。 不要向客户端泄漏信息........................................... 错误!未定义书签。 记录详细的错误信息 ............................................ 错误!未定义书签。 捕捉异常 ...................................................... 错误!未定义书签。 不要信任 HTTP 头信息........................................ 错误!未定义书签。 不要使用 HTTP-GET 协议传递敏感数据 .......................... 错误!未定义书签。 不要在永久性 cookie 中存储敏感数据 .......................... 错误!未定义书签。 对数据进行加密或确保通信通道的安全 .......................... 错误!未定义书签。 SQL 语句的参数应以变量形式传入 .............................. 错误!未定义书签。 页面中的非源代码内容应经过 URI 编码 ......................... 错误!未定义书签。

WEB应用系统安全规范文档

WEB 应用系统安全规范 目录 WEB应用系统安全规范 ............................. 错误!未定义书签。 1 概述................................... 错误! 未定义书签。 目的............................................................................. 错误! 未定义书 签。 适用范围 ......................................................................... 错误! 未定义书 签。 2 范围................................... 错误! 未定义书签。 3 名词解释.................................. 错误! 未定义书签。 4 WEB开发安全规范.............................. 错误!未定义书签。 VEB应用程序体系结构和安全............................ 错误!未定义书签。 VE B安全编码规范 ............................... 错误!未定义书签。 区分公共区域和受限区域. ........................................ 错误!未定义书签。 对身份验证cookie 的内容进行加密. .................................... 错误!未定义书签。 限制会话寿命............................ 错误!未定义书签。 使用SSL 保护会话身份验证Cookie . ................................... 错误!未定义书签。 确保用户没有绕过检查.......................... 错误!未定义书签。 验证从客户端发送的所有数据. ........................................ 错误!未定义书签。 不要向客户端泄漏信息.......................... 错误! 未定义书签。 记录详细的错误信息......................... 错误! 未定义书签。 捕捉异常.............................. 错误!未定义书签。 不要信任HTTP 头信息...................... 错误! 未定义书签。 不要使用HTTP-GET 协议传递敏感数据 ............... 错误! 未定义书签。 不要在永久性cookie 中存储敏感数据.................. 错误! 未定义书签。 对数据进行加密或确保通信通道的安全................. 错误!未定义书签。 SQL 语句的参数应以变量形式传入 .................. 错误!未定义书签。 页面中的非源代码内容应经过URI 编码................ 错误! 未定义书签。 页面中拼装的脚本应校验元素来源的合法性............... 错误! 未定义书签。 页面请求处理应校验参数的最大长度................. 错误! 未定义书签。 登录失败信息错误提示应一致.................... 错误! 未定义书签。 避免页面上传任意扩展名的文件.................... 错误! 未定义书签。 避免接受页面中的主机磁盘路径信息................. 错误! 未定义书签。 第三方产品的合法性......................... 错误! 未定义书签。 5 系统部署安全规范.............................. 错误! 未定义书签。 部署架构和安全 .................................................................. 错误!未定义书签。 网络基础结构组件........................... 错误!未定义书签。

Java Web安全开发规范

Java Web安全开发规范

1.目的 保障WEB应用平台的安全性,保证WEB应用系统的可用性、完整性和保密性从安全角度规范WEB应用系统开发人员,能够让WEB应用开发者树立很强的安全意识,在开发过程中编写安全代码,进行安全编程。 2.范围 本规范从应用安全开发角度出发,给出WEB应用系统安全开发的规范。供软通动力内部使用,适用各个WEB应用系统项目开发的工作。 本规范定义了WEB应用系统安全开发和WEB编码安全相关的技术要求。 3.规范概述 WEB应用系统为架构设计人员、开发人员提出了一系列复杂的安全问题。最安全、最有能力抵御攻击的Web应用程序是那些应用安全思想构建的应用程序。 在设计初始阶段,应该使用可靠的安全体系结构和设计方法,同时要结合考虑应用程序的部署以及企业的安全策略。如果不能做到这一点,将导致在现有基础结构上部署应用程序时,要不可避免地危及网站系统的安全性。 本规范提供初步的安全体系结构和设计指南,并按照常见的应用程序漏洞类别进行组织。这些指南是WEB应用程序安全的重要方面,并且是经常发生错误的领域。 4.安全编码原则 ◆程序只实现你指定的功能 ◆永不要信任用户输入,对用户输入数据有效性检查 ◆必须考虑意外情况并进行处理 ◆不要试图在发现错误之后继续执行 ◆尽可能使用安全函数进行编程 ◆小心、认真、细致地编程 5.软件编码安全 5.1.输入校验 WEB应用程序从各个方面获取输入,例如所有用户发送的,或者Web应用程序与用户

交互往返的数据(用户提交的数据,cookie信息,查询字符串参数),以及后台数据(数据库、配置文件、其他数据来源)。所有输入的数据都会在某种情况下影响请求的处理。 正确的输入验证是防御目前应用程序攻击的最有效方法之一。正确的输入验证是防止XSS、SQL注入、缓冲区溢出和其他输入攻击的有效对策。 以下做法可以增强Web应用程序的输入验证: 假定所有输入都是恶意的 开始输入校验时,首先假定所有输入都是恶意的,除非有证据表明它们并无恶意,无论输入是来自服务、共享文件、用户还是数据库,只有其来源不在 可信任的范围之内,就应对输入进行验证。 集中方法 将输入验证策略作为应用程序的核心元素。考虑集中式验证方法,例如通过使用共享库中的公共验证和筛选代码。这确保验证规则应用的一致性。此外 还能减少开发工作量,并且有助于以后的维护工作。 不要依赖客户端验证 应使用服务器端代码执行其自身的验证,如果攻击者绕过客户端或者禁用客户端JavaScript脚本,后果如何?使用客户端验证可以减少客户端到服务器 端的往返次数,但是不要依赖这种方法进行安全验证。 注意标准化问题 数据的标准形式是最标准、最简单的形式。标准化是指将数据转化为标准形式的过程。文件路径和URL尤其倾向于标准化问题。 例如/www/public/testfile.jsp /www/public/../public/testfile.jsp /www/public///testfile.jsp %2fwww%2fpublic%2f%2f%2ftestfile.jsp 都表示同一个文件。 通常,应设法避免让应用程序接受用户输入的文件名,以防止标准化问题。 可以考虑其他方式,例如由应用程序为用户确定文件名。如果确实需要用户输 入文件名,在作出安全决策(如授予或拒绝特定文件的访问权限)之前应确保 这些文件名具有严格定义的形式。 限制输入 定义应用程序字段可以接受的数据输入,并强制应用该定义,拒绝一切有害数据。 验证数据的类型、长度、格式和范围 在适当的地方对输入数据使用强类型检查,可以使用参数化的存储过程来访问数据。 应该检查字符串字段的长度,在许多情况下还应检查字符串的格式是否正确,例如邮政编码、手机号码、身份证号码等都具有明确定义的格式,可以使 用常规表达式进行验证。长度检查会加大攻击者实施其所喜欢的攻击方式的难 度。 拒绝已知的有害输入 例如查询条件中禁止输入or 1=1等。 净化输入 净化包括从删除用户输入字符串后面的空格到去除值等一切行为。常见的净化输入示例是使用URL编码或者HTML编码来包装数据,并将其作为文本而

WEB应用系统安全规范

W E B应用系统安全规范 Document number:BGCG-0857-BTDO-0089-2022

WEB应用系统安全规范 目录

1概述 1.1目的 为规范我司Java Web应用编码和部署的安全控制和管理,特制定本规范,并作为安全检查及考核的参考依据。

1.2适用范围 本规范适用于我司所有在线Java业务系统、测试系统的WEB应用。 本规范可作为其他非WEB应用的编码和部署安全办法参考。 2范围 本规范中列出的是常见安全措施和高风险的漏洞,在系统开发与系统部署的过程中,对本规范未能尽述的必要安全措施,仍应予以采用。 本规范每年复审一次,其它时候也可以根据需要进行修订并发布。本规范的解释权和修改权归属信息技术部。 3名词解释 验证:通讯实体(例如,客户端和服务器)彼此验证,以经过访问授权的特定标识为依据。 资源的访问控制:资源的交互仅限于某些用户或程序的集合,其目的是对完整性,保密性或可用性实施强制约束。 数据完整性:检验信息是否被第三方(非信息源的其它实体)修改。例如,处于开放网络环境中的数据接收方必须能够检测并丢弃那些在传递过程中被修改过的消息。 机密性或数据隐私:确保信息仅对经过访问授权的用户可用。 不可否认:对用户进行检验,让他无法否认自己进行过的活动。

审核:捕获一个安全相关事件的防篡改记录,目的是评估安全策略和机制的有效性。 4Web开发安全规范 4.1Web应用程序体系结构和安全 HTTP 是无国界的,这意味着跟踪每位用户的会话状态将成为应用程序的责任。应用程序必须能够通过某种形式的身份验证来识别用户。由于所有后续授权决策都要基于用户的标识,因此,身份验证过程必须是安全的,同样必须很好地保护用于跟踪已验证用户的会话处理机制。设计安全的身份验证和会话管理机制仅仅是Web 应用程序设计人员和开发人员所面临的众多问题中的两个方面。由于输入和输出数据要在公共网络上进行传输,因此还会存在其他挑战。防止参数操作和敏感数据泄漏也是另外一些重要问题。

系统安全配置技术规范-Websphere

系统安全配置技术规范—Websphere 版本V0.9 日期2013-06-03 文档编号 文档发布

文档说明 (一)变更信息 版本号变更日期变更者变更理由/变更内容备注 (二)文档审核人 姓名职位签名日期

目录 1.适用范围 (4) 2.帐号管理与授权 (4) 2.1【基本】控制台帐号安全 (4) 2.2【基本】帐号的口令安全 (4) 2.3【基本】为应用用户定义合适的角色 (5) 2.4【基本】控制台安全 (5) 2.5【基本】全局安全性与J AVA 2 安全 (6) 3.日志配置要求 (6) 3.1【基本】开启应用日志记录 (6) 4.服务配置要求 (7) 4.1【基本】禁止列表显示文件 (7) 4.2【基本】禁止浏览列表显示目录 (7) 4.3【基本】删除示例程序 (8) 4.4【基本】控制台超时设置 (8) 4.5【基本】更新 W EB S PHERE补丁 (8) 4.6【基本】备份容错 (9) 4.7设置错误页面 (9) 4.8配置 SSL 访问 (9) 4.9控制目录权限 (11) 5.操作系统配置要求 (11)

1.适用范围 如无特殊说明,本规范所有配置项适用于IBM WebSphere Application Server (WAS) 6.x,7.x ,8.x 版本。其中标示为“基本”字样的配置项,均为本公司对此类系统的基本安全配置 要求;未标示“基本”字样的配置项,请各系统管理员视实际需求酌情遵从。 2.帐号管理与授权 2.1 【基本】控制台帐号安全 配置 WebSphere 控制台帐号安全,要求按权利需要分配不同用户角色,同时 配置项描述 保证权限最小化 以管理员身份打开管理控制台,执行: 检查方法 1.点击“系统管理”-->”控制台设置”-->“控制台用户” 2.点击要查看的用户名 3.查看用户所属组 要求不得出现共用特权管理帐号,管理帐号必须按角色分配用户角色为 操作步骤monitor(监控员)、Configurator( 配置员 )、Operator(操作员) Administrator( 管理员 )之 回退操作回退到原有的配置设置 操作风险低风险 2.2 【基本】帐号的口令安全 配置项描述配置 WebSphere 口令安全,要求用户口令至少 6 位,包括大小写,数字和符号中的至少两种 检查方法 询问管理员是否存在如下类似的简单用户密码配置,比如: Test、 netscreen、 admin、 root1234 操作步骤检查用户口令的设置情况,检查是否存在简单密码。要求密码长度最少为6位,包含大小写字母、数字和特殊符号,密码变更周期。 回退操作回退到原有的配置设置

WEB应用系统安全规范

WEB应用系统安全规范 目录 WEB应用系统安全规范 (1) 1概述 (2) 1.1目的 (2) 1.2适用范围 (3) 2范围 (3) 3名词解释 (3) 4WEB开发安全规范 (4) 4.1W EB应用程序体系结构和安全 (4) 4.2W EB安全编码规范 (6) 4.2.1区分公共区域和受限区域 (6) 4.2.2对身份验证cookie 的内容进行加密 (6) 4.2.3限制会话寿命 (6) 4.2.4使用SSL 保护会话身份验证Cookie (6) 4.2.5确保用户没有绕过检查 (6) 4.2.6验证从客户端发送的所有数据 (7) 4.2.7不要向客户端泄漏信息 (7) 4.2.8记录详细的错误信息 (7) 4.2.9捕捉异常 (7) 4.2.10不要信任HTTP 头信息 (7) 4.2.11不要使用HTTP-GET 协议传递敏感数据 (7) 4.2.12不要在永久性cookie 中存储敏感数据 (7) 4.2.13对数据进行加密或确保通信通道的安全 (8) 4.2.14SQL 语句的参数应以变量形式传入 (8) 4.2.15页面中的非源代码内容应经过URI 编码 (8) 4.2.16页面中拼装的脚本应校验元素来源的合法性 (8) 4.2.17页面请求处理应校验参数的最大长度 (8) 4.2.18登录失败信息错误提示应一致 (9) 4.2.19避免页面上传任意扩展名的文件 (9) 4.2.20避免接受页面中的主机磁盘路径信息 (9) 4.2.21第三方产品的合法性 (9) 5系统部署安全规范 (9) 5.1部署架构和安全 (9) 5.1.1网络基础结构组件 (10)

相关文档
最新文档