新客网WWW.XKER.COM:致力做中国最专业的网络学院!
模糊搜索
标题搜索
最新更新
新客商城
网站地图
RSS订阅
首页
新闻中心
网络学院
软件开发
站长之家
软件下载
手机学院
桌面壁纸
专题
论坛
学院:
操作系统
-
网络应用
-
服务器
-
网络安全
-
工具软件
-
办公软件
-
Web开发
-
数据库
-
网页设计
-
图形图像
-
媒体动画
-
硬件学堂
-
存储频道
-
QQ专区
您的位置:
首页
>
软件开发
>
.Net开发
>
Asp.net教程
> 正文:在ASP.NET中防止注入攻击
在ASP.NET中防止注入攻击
新客网
XKER.COM
2006-04-26 来源:
收藏本文
目的:
对输入的字串长度,范围,格式和类型进行约束.
在开发ASP.NET程序时使用请求验证防止注入攻击.
使用ASP.NET验证控件进行输入验证.
对不安全的输出编码.
使用命令参数集模式防止注入攻击.
防止错误的详细信息被返回到客户端.
概述 :
你应该在程序中验证所有的不信任输入.你应该假定所有的用户输入都是非法的.用户可以在应用程序中提供表单字段,查询字串,客户端cookies和浏览器环境值比如用户代理字串和IP地址等.
弱输入校验通常为注入攻击提供了机会.下面是常见的利用弱输入校验或无输入校验进行攻击的手段.
SQL 注入(SQL injection).
如果你使用用户的输入值来动态构造SQL语句,那么数据库可能执行攻击性的有害SQL语句.
跨站脚本(Cross-site scripting).
跨站脚本攻击利用网页验证漏洞注入客户端脚本.接下来这些代码被发送到受信任的客户端电脑上并被浏览器解释执行.因为这些代码来自受信任的站点,所以浏览器无法得知这些代码是有害的.
未授权的文件访问(Unauthorized file
access
).
如果你的代码从调用者那里接受输入,恶意用户可以看到你对文件的操作过程从而访问那些受保护的文件或者使用你的代码注入非法数据.
注意 : 注入攻击可通过使用HTTP或HTTPS Secure Socket Layer(SSL) 连接. 传输加密技术不能用来防御攻击.
通常的输入验证方法总结如下.你应在所有的需要通过网络输入的地方进行验证,比如文本框和其它表单输入字段, 查询字串参数,cookies,服务器端变量和网络方法参数.注意,过滤策略应该是只允许正确的输入然后拒绝非法输入.这是因为定义正确的输入策略比过滤所有的非法输入要容易,那通常很难包括所有的非法输入.
通入如下几个方面验证输入内容:
约束.
验证是否输入的是正确的类型,字符长度,格式和范围.可以应用ASP.NET验证控件来约束服务器控件输入.约束其它来源的输入可以使用正则表达式和自定义的验证规则.
拒绝.
检测已知的有害数据输入并拒绝.
过滤.
有时候你会希望过滤掉用户输入中那些有安全隐患的那些部分.例如,你的程序允许自由格式的输入,比如备注字段,你会允许特定的安全HTML标记象<b>,<i>及其它的HTML标记.
步骤提要
通过以下步骤保护你的ASP.NET程序不受注入式攻击危害 :
第一步.使用ASP.NET请求验证.
第二步.约束输入.
第三步.对不安全的输出进行编码.
第四步.对SQL查询语句使用命令参数.
第五步.验证ASP.NET的出错信息没有泄漏至客户端.
下面的章节将对这些步骤进行详细讨论.
第一步.使用ASP.NET请求验证.
默认地,ASP.NET 1.1和2.0请求验证会对送至服务器的数据检测是否含有HTML标记元素和保留字符.这可以防止用户向程序中输入脚本.请求验证会对照一个有潜在威胁的字符串列表进行匹配,如果发现异常它会抛出一个HttpRequestValidationException类型的异常.
你可以在你的web.config文件中的
<pages>
元素中加入
validateRequest="false"
或在单独的页面的
@Pages
元素里面设置
ValidateRequest = "false"
来禁用此项功能.
如果你想禁用请求验证功能,你可以仅在需要的页面禁用它.比如你在程序页面上包含一个可接受HTML格式输入的字段.
确定在Machine.config文件中请求验证功能被打开.
请求验证功能在ASP.NET中被默认启用.你可以在Machine.config.comments文件中看到如下的默认设置.
<pages validateRequest = "true" ... />
确认你没有修改你的服务器的Machine.config和应用程序的Web.config文件里的默认设置.
测试ASP.NET请求验证
你可以测试请求验证的作用.创建一个ASP.NET页面通过设置ValidateRequest = "fasle"禁用请求验证,代码如下 :
<%@ Language="C#" ValidateRequest="false" %>
<html>
<script runat="server">
共6页:
上一页
[1]
[2]
[3]
[4]
[5]
[6]
下一页
上一篇:
ASP.NET页面中标题单点解决方案
下一篇:
ASP.NET 2.0站点登录、导航与权限管理
【
收藏
】 【
评论
】 【
推荐
】 【
投稿
】 【
打印
】 【
关闭
】
最新相关文章
·
身份证函数 查看身份证地区信息
·
VS2008 第一次安装心得及使用
·
ASP.NET 2.0跨网页提交的三法
·
编程实例 WebGroupBox(Aspx控件)
·
asp.net mvc脚手架代码生成工具
·
用独立的DLL来存储图片(资源文件)
·
ASP.NET中多国语言的实现方法
·
实例 .net生成静态页方法总结
·
ASP.NET控件学习笔记之ViewState
·
用递归在TreeView价节点
·
经验总结 关于.NET 中的Event机制
·
.NET应用程序开发标准化(z)
·
在DataTable中查询应该注意的问题
·
LINQ 中调用存储过程自动绑定列名
·
如何用.NET技术在线生成网站LOGO
·
对于访问IIS元数据库失败的解决
发表评论
(
要记得去论坛讨论,点击注册新会员
)
匿名评论
评论内容:不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
阅读排行
Asp.net Ajax 中的脚本错误: Sys未定义 的解决方
身份证号码15位升18位(C#)
asp.net ajax学习系列功能强大的UpdatePanel控件
Web Service描述语言 WSDL 详解(1)--为什么使用WS
Asp.Net Unleashed 2nd Edition 学习笔记 第三部
UpdatePanel与UrlRewrite
DataGridView 的分页处理
从资源文件里加载文件(C#)
Javascript与asp.net 实现Ajax多文件无刷新上传
关于ASP.NET调用JavaScript的实现
asp.net面试试题收集
基于ASP.NET AJAX的WebPart开发与部署
Huffman 编码简介(讲解的更好一些,有C的分析)
在VC++应用程序中读取文本数据
技巧 .NET如何访问MySQL数据库
专题教程
非主流Ps教程
磁碟机病毒专杀
AV终结者
会声会影教程
nero教程
FreeBSD使用大全
PDF阅读器
BT下载
QQ防骗术案例剖析
机器狗病毒查杀专题
搜狗拼音输入法专题
google earth专题
随机推荐
自己写的label 与 textBox 组合的控件
.NET Test Driven Development
asp.net验证码生成类(参考)
各种媒体在线播放代码
ASP.NET创建Web服务之声明
c#重点知识详解(六)
使用JScript.NET创建asp.net页面(二)
C#代码的编译与执行过程(摘自ms inside c#)
獲取SQL SERVER用戶表信息游標
ASP.NET简单整理收藏(2)
DataGrid的用法(一)基本用法
ADO+ 引导数据种类的演变 (转自 ms 二)
Using Attributes in C#
Introduction to .NET Reflection
变向实现动态水晶报表
实用信息推荐
常用网页广告代码全集
中国电子地图
IP查询、IP签名
免费代理IP(每日更新)
免费周公解梦大全
html互转JS
FLASH休闲小游戏
flash动画
qq搞笑表情
最新电影大片
戴尔dell笔记本电脑订购
戴尔dell台式机电脑订购