软件安全性测试(连载5)

简介: 软件安全性测试(连载5)

6. XSS防护方法


XSS防护方法主要包括特殊字符转义和HTTPOnlyHTTPOnly上面已经介绍过,这里来介绍一下特殊字符转义。


1)编码内容:HTML内容

  •  转义清单

Ø    &->&amp

Ø    <->%lt>

Ø    >->%gt

Ø    "->&#34

Ø    '->&#39


  •  例子与说明

Ø    <span>需要编码的数据</span>

Ø    <div>需要编码的数据</div>:使用特定的HTML解析器处理库。

2)编码内容:HTML属性


  •     转义清单

Ø    不安全属性,比如:namevalue

Ø    &< > " '->&#HH


  •     例子与说明

Ø    <input type="text" name="name" value="需要编码的数据">:仅用于安全属性,不安全属性进行HTML属性编码。

Ø    对于srchref属性,比如<iframesrc="需要编码的数据"/>,需要通过基于白名单验证URL。只能允许HTTP头、HTTPS头,避免JavaScript头。

3)编码内容:JavaScript


  •     转义清单

Ø    JavaScript代码进行JavaScript编码。

Ø    特殊字符转换为\xHH形式。

Ø    不要使用\形式编码,容易受到双重转移攻击\\

Ø    将变量放在引号内,不以被执行。比如如下代码。

var x = $var
var y = "$var"
x=1;alert(2);       //alert可执行
y="x=1;alert(2);"  //alert不可以执行,比较安全


  • 例子与说明

Ø    <script>var xx="需要编码的数据";</script>JavaScript编码。

4)编码内容:CSS


  •     转义清单

Ø    将不可信任的数据放在安全属性中,进行CSS编码(不安全属性,不如URLbehavior)。

Ø    将不可信任的数据放在JavaScript表达式属性中。

Ø    URL不以javasvript开头。

Ø    其他属性不以expression开头。


  •      例子与说明

Ø    <div style="width:需要编码的数据">Selection</div>。仅用于安全属性;不安全属性需要CSS样式编码。

5)编码内容:URL参数


  •     转义清单

Ø    <a href= "http://www.somesite.com?test=URL编码数据"></a>

Ø    URL编码:数字、字母、特殊字符编码成%HH格式。


  • 例子与说明

Ø    <a href="/site/sraech?value=需要编码的数据">URL编码。

6)编码内容:自定义HTML标签


  •      转义清单

Ø    .NETHTMLSanitizer

Ø    JAVA库:OWSAP Java HTMLSanitizer;

Ø    Ruby库:Ruby onRails SanitizeHelper

Ø    PHP库:PHP HTMLPurifier

Ø    JavaScript库:JavaScript/Node.js Bleach

Ø    Python库:PythonBleach


      12为安全的HTML属性。

image.png

12 安全的HTML属性


ESAPI (OWASP企业安全应用程序接口)是一个免费、开源的、网页应用程序安全控件库,它使程序员能够更容易写出更低风险的程序。ESAPI接口库被设计来使程序员能够更容易的在现有的程序中引入安全因素。ESAPI库也可以成为作为新程序开发的基础。ESAPI主要支持JAVA语言。其使用方法可以参照网上介绍。


4展示的是ESAPI中哪些特殊符号在何种情况下需要转义;5表示ESAPI中特殊符号转义成什么字符。


4 OWASP ESAPI中哪些特殊符号在何种情况下需要转义

编码类型

&

"

'

/

\

=

`

(

)

\t

\n

\f

\r

\b

空格

下一行

行隔

段隔

\u00000~\u001f

文本内容及属性

b

b

b

b

b

















文本内容

b

b

b



















文本属性

b

b


b

b

















未加引号的属性

b

b


b

b

b


b

b



b

b

b

b


b

b

b

b


CSS字符串

b

b

b

b

b

b

b















CSS URL










b

b











URL一个组件

b

b

b

b

b

b

b



b

b











JavaScript字符串

b



b

b

b

b





b

b

b

b

b

b




b


5 OWASP ESAPI中特殊符号转义成什么字符

符号

转换

符号

转换

&

&amp; \26(用于CSSJavaScriptURL

)

\29(用于CSSURL

&lt; \3c(用于CSSURL

下一行\u0085

&#133

&gt; \3e(用于CSSURL

行分隔符:\u2028

&#8232

"

&#34   \22(用于CSSJavaScriptURL

换行符:\u000A

&#10 \n(用于JavaScript

'

&#39    \27(用于CSSJavaScriptURL

换页符: \u000C

&#12 \f(用于JavaScript

/

&#47   \2f(用于CSSURL\/(用于CSSJavaScript

回车符:\u000D

&#13 \r(用于JavaScript

 \

\5c(用于CSSURL\\(用于JavaScript

退格符:\u000A

\b(用于JavaScript

=

&#61

空格符:\u0020

&#32

`

&#96

段落分隔符:\u2029

&#8233

(

\28(用于CSSURL

\u00000~\u001f

\X##(用于JavaScript


下面对常用的OWASP ESAPI进行一一讲解。(注OWASP ESAPI除了JAVA版本,还有ASP.NETPHPPythonJavaScript等多个版本,这里介绍的是JAVA版本)。


函数:String forHtml(String input)

说明:对文本内容及文本属性编码。

例子:

<div><%=Encode.forHtml(UserData)%></div>


函数:String forHtmlContent(Stringinput)

说明:对文本内容编码。

例子:

<div><%=Encode.forHtmlContent(UserData)%></div>


函数:String forHtmlAttribute(Stringinput)

说明:对文本属性编码。

例子:

<input type="text"name="name" value="Encode.forHtmlAttribute(UserData)">


函数:StringforHtmlUnquoteAttribute(String input)

说明:未加引号的属性进行编码。

例子:

<input type="text"name="name" value="Encode.forHtmlUnquoteAttribute(UserData)">


函数:String forCssString(String input)

说明:编码CSS字符串,字符串必选在引号内。

例子:

<div style="width:Encode.forCssString(UserData)">Selection</div>


函数:String forCssUrl(String input)

说明:编码CSS URL,必须在url()内。

例子:

<divstyle="background:url(<%=Encode.forCssUrl(…)%>)">
<styletype="text/css">
     background:url(<%=Encode.forCssUrl(…)%>)
</style>


函数:String forUrlComponent(Stringinput)

说明:对URL一个组件进行编码。

例子:

<ahref="http://www.mydoman.com/<%=Encode.forUrlComponent(…)%>?query#fragment">


函数:String forJavaScript(Stringinput)

说明:编码JavaScript字符串。

例子:

<buttononclick="alert('<%=Encode.forJavaScript(data)%>');">
<script>
       var data ="<%=Encode.forJavaScript(data)%>";
</script>


函数:StringforJavaScriptAtribute(String input)

说明:编码JavaScript属性。

例子:

<buttononclick="alert('Encode.forJavaScriptAtribute(data)%>');">


函数:String forJavaScriptBlock(Stringinput)

说明:编码JavaScript实体属性。

例子:

<script>
       var data = "<%=Encode.forJavaScriptBlock(data)%>";
</script>


      除了OWASP ESAPI,还有一些企业提供了防止XSS注入的API,它们是。

  • OWASP JAVA HTML Sanitizer,包括。

Ø    Sanitizer.FORMATTING.sanitize(html)

Ø    Sanitizer.BLOCKS.sanitize(block)

Ø    Sanitizer.STYLES.sanitize(attribute)

Ø    Sanitizer.LINKS.sanitize(link)

Ø    Sanitizer.TABLES.sanitize(html)

Ø    Sanitizer.IMAGES.sanitize(img)


  • AnjularJS SCE:这是Google开发并维护的一套JavaScript框架,包括。

Ø    getTrustedHtml(value)

Ø    getTrustedCss(value)

Ø    getTrustedUrl(value)

Ø    getTrustedResourceUrl(value)

Ø    getTrustedJs(vaule)

Ø    trustAsHtml(value)

Ø    trustAsCss(value)

Ø    trustAsUrl(value)

Ø    trustAsResourceUrl(value)

Ø    trustAsJs(value)


  • ESAPI4JS:这是OWASP ESAPIJavaScript版本,包括。

Ø    encodeForHTML()

Ø    encodeForURL()

Ø    encodeForCSS()

Ø    encodeForHTMLAttribute()

Ø    encodeForJavaScript()

Ø    normal():过滤无法识别数据比如:ぢ。

Ø    cananicalize()还原 &amp;&lt;->&<


  • JQuery Encode:类似于ESAPI4JS,包括。

      Ø    encodeForHTML();

Ø    encodeForHTMLAttribute()

Ø    encodeForCSS()

Ø    encodeForJavaScript()

Ø    encodeForURL()


除了使用特殊字符转义和HTTPOnly以外,还可以考虑在HTTP包里包含以下表头信息。


  • 使用安全策略(CSP):CSPContent-Security-Policy的缩写。
  • X-XSS-Protection响应头。X-XSS-Protection响应头包括以下四种模式。

Ø    0:禁用XSS过滤器。

Ø    1:启用XSS过滤器(默认)。

Ø    1; mode = block:如果找到XSS,则不要渲染文档。

Ø    1; report = URL:如果找到XSS,对页面修改并且报告URL


在这里建议使用X-XSS-Protection:1; mode=block模式

总结一下,防止CSS注入可以采取以下四种方式。

  • 输入检查并转义。
  • 使用ESAPI等规范。
  • 输出检查并转义。
  • 使用安全的表头。

一般而言在服务器端进行如下处理。

  • 输出编码,工具OWASP Java Encode
  •  HTML过滤,工具OWASP Java HTML Sanitizer
  • Cookie设置HTTPOnly
  • 启用CSP策略。
  • 添加X-XSS-Protection响应头。


而在客户端采取下面的处理。

  • 输出编码,工具ESAPI4JjQuery Encoder
  • 自动上下文转义,工具AngularJS
  • JavaScript安全编码。

对于存储式XSS注入应该输出检查并转义还是输入检查并转义比较好?作者认为应该是输出检查并转义,这样可以确保存储在数据库、文件或其他容器中的数据可以被不同的前端应用。


星云测试

http://www.teststars.cc

奇林软件

http://www.kylinpet.com

联合通测

http://www.quicktesting.net


顾翔凡言:


图是软件项目三角形。

image.png

 软件项目三角形


      下面做如下假设。

l 假设质量(Q)与范围(S)不变,时间(T)减少的情形下,必须雇佣高水平的人员或者先进的技术,即增大产品的成本(C)。同理,质量(Q)与范围不变,时间(T)增加的情形下,可以减少成本(C)。

l 假设质量(Q)与时间(T)不变,范围(S)增加的情形下,也必须增大成本(C)。同理,质量(Q)与时间(T)不变,范围(S)减少的情形下,可以减少成本(C)。

l 假设质量(Q)与成本(C)不变,时间(T)减少的情形下,范围(S)必须减少。同理,质量(Q)与成本(C)不变,时间(T)增加的情形下,可以加大范围(S)。


于是可以得到如下公式:

Q = TC/S

 也就是说质量消耗单位模块的时间和金钱的乘积。从这里可以看出,完成一个功能,需要达到一定的质量,必须消耗有效的时间或者增加产品的成本投入,由此可以看出为了赶进度,盲目加班赶工是不可取的。

目录
相关文章
|
SQL 存储 Oracle
软件安全性测试(连载11)
软件安全性测试(连载11)
125 0
软件安全性测试(连载11)
|
安全 Java PHP
软件安全性测试(连载15)
软件安全性测试(连载15)
133 0
软件安全性测试(连载15)
|
SQL 存储 安全
软件安全性测试(连载21)
软件安全性测试(连载21)
162 0
软件安全性测试(连载21)
|
缓存 安全 Java
软件安全性测试(连载22)
软件安全性测试(连载22)
125 0
软件安全性测试(连载22)
|
SQL 缓存 网络协议
软件安全性测试(连载23)
软件安全性测试(连载23)
126 0
软件安全性测试(连载23)
|
存储 JavaScript 前端开发
软件安全性测试(连载3)
软件安全性测试(连载3)
114 0
软件安全性测试(连载3)
|
安全 程序员 网络安全
软件安全性测试(连载18)
软件安全性测试(连载18)
102 0
软件安全性测试(连载18)
|
存储 安全 Java
软件安全性测试(连载24)
软件安全性测试(连载24)
130 0
软件安全性测试(连载24)
|
前端开发 JavaScript 安全
软件安全性测试(连载13)
软件安全性测试(连载13)
159 0
软件安全性测试(连载13)
|
前端开发 JavaScript
软件安全性测试(连载4)
软件安全性测试(连载4)
68 0

相关实验场景

更多