Tag:开源 , 源码 , 控件 , 控件开发 , 皮肤 , Skin , MVC , WCF , Remoting , AJAX , JQuery , Flex , Silverlight , SQL Server , 设计模式 , 框架 , 正则 , Web服务 , 数据库 , PetShop , WordPress , HTML编码 , 防止脚本侵入

 
您的位置: >> 首页 >> .Net博文 >> 对字符串应用 HTML编码 防止脚本侵入

对字符串应用 HTML编码 防止脚本侵入

2010-08-22  来自:百度空间  字体大小:【  
  • 摘要:本文介绍如何对字符串应用 HTML编码 防止脚本侵入

        大多数脚本利用发生在用户可以将可执行代码(或脚本)插入您的应用程序时。默认情况下,ASP.NET 提供请求验证。只要窗体发送包含任何 HTML,该验证都会引发错误。

您可以使用下列方法防止脚本利用:

  • 对窗体变量、查询字符串变量和 Cookie 值执行参数验证。该验证应包括两种类型的验证:可以将变量转换为所需类型(如转换为整数、日期时间等)的验证,以及所需范围或格式的验证。例如,应该使用 Int32..::.TryParse 方法来检查应为整数的窗体发送变量,以验证该变量是否确实为整数。而且,还应该检查得到的整数,以验证该值是否在所需值范围之内。

  • 将值写回响应时,向字符串输出应用 HTML 编码。这有助于确保用户提供的所有字符串输入将以静态文本形式呈现在浏览器中,而不是呈现为可执行的脚本代码或已解释的 HTML 元素。

HTML 编码使用 HTML 保留字符转换 HTML 元素,以便显示它们而不是执行它们。

向字符串应用 HTML 编码

  • 显示字符串之前,调用 HtmlEncode 方法。HTML 元素会转换为浏览器将显示(而不解释为 HTML)的字符串表示形式。

    下面的示例说明 HTML 编码。在第一个实例中,在显示用户输入之前对其进行编码。在第二个实例中,在显示数据库中的数据之前对其进行编码。

    说明:

    只有通过添加 @ Page 属性 ValidateRequest="false" 在页中禁用请求验证
    时,此示例才起作用。建议不要在成品应用程序中禁用请求验证,因此,请确保在查
    看本示例之后重新启用请求验证。

    Visual Basic
    Private Sub Button1_Click(ByVal sender As System.Object,
        ByVal e _
        As System.EventArgs) Handles Button1.Click
            Label1.Text = Server.HtmlEncode(TextBox1.Text)
            Label2.Text = _
                Server.HtmlEncode(
                dsCustomers.Customers(0).CompanyName)
    End Sub
    

     

    C#
    private void Button1_Click(object sender, 
       System.EventArgs e)
    {
        Label1.Text = Server.HtmlEncode(TextBox1.Text);
        Label2.Text = 
            Server.HtmlEncode(
            dsCustomers1.Customers[0].CompanyName);
    }
    
作者:jqbxxf
上一篇:提高ASP.NET效率      下一篇:详解asp.net性能优化
相关文章:
该文章已有条评论 我要发表评论