• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Asp.net之数据过滤浅析

asp 搞代码 4年前 (2022-01-03) 34次浏览 已收录 0个评论

在B/S开发中,安全性能应该是需要注意的,很多年前有位高人说过,凡是来自客户端的数据,都是不可信的,今天开发时,把数据过滤的方法重写了一下,所以忍不住想拿出来讨论下,欢迎大家指点

在Asp.net开如中,引发安全问题最多的大多来自于以下三个方面:
  1.上传
  2.跨站
  3.注入
  上传的安全问题不在本文讨论范围内,这里只讨论跨站与注入的问题,而这两者都是基本可以通过过滤来处理的!把注入放在最后面是因为,SQL注入玩了这么多年,大家应当有了一定的防范,只要稍有点注意,能在asp.net上面玩下的注入还是相当少的!注意这以下几点。
  1.所有的参数。如果是int类型的,请转换成int再处理! 别拿装箱与拆箱来说事!估计现在大家也不会把sql语句直接在web里面拼接了,起码也要用上几个类,中间的一些简单的逻辑处理!类型转换还是要涉及到的
  2.尽量使用参数化查询!
  3.起码要注意过滤单引号(其实如果使用参数化查询,不过滤也没事,不过我还是习惯性过滤)!
  4.不要直接把错误赤裸裸的暴露给用户!这点不仅仅是为了防范注入,同时也是一个用户体验问题!通过重写OnError事件,再继承,能很好的处理!
  而相对于跨站,防洗耳范起来就麻烦多了,过滤一直是个很纠结的东西,过滤太严了,影响正常使用,没过滤好,又引发安全问题!我把我刚写的过滤类拿出来,也许其中还有没有考虑到的地方,希望大家指点,

代码如下:
public static string StringFilters(string input)
{
if (string.IsNullOrEmpty(input))
return input;
/*跨站攻击过虑*/
input = input.Replace(“&#”, “&#”);//过滤&# 攻击方式&#x6A&#x61&#x76&#x61&#x73&#x63&#x72&#x69&#x70&#x74&#x3A&#x61&#x6C&#x65&#x72&#x74&#x28&#x27&#x58&#x53&#x53&#x27&#x29
input = Regex.Replace(input, @”javascript:”, “Javascript:”, RegexOptions.IgnoreCase);//过滤JS 攻击方式:javascript:alert(‘XSS’);
input = Regex.Replace(input, @”vbscript:”, “Vbscript:”, RegexOptions.IgnoreCase);//过滤JS 攻击方式:vbscript:msgbox(‘XSS’);
input = Regex.Replace(input, @”j *a *v *a *s *c *r *i *p *t:”, “Vbscript:”, RegexOptions.IgnoreCase);//攻击方式:java script:alert(‘XSS’);
input = Regex.Replace(input, @”\/\*[sS]*\*\/”, ““, RegexOptions.IgnoreCase);
input = Regex.Replace(input, @”expression”, “expression”, RegexOptions.IgnoreCase);
input = Regex.Replace(input, @”]*>”, “S:yle”, RegexOptions.IgnoreCase);
input = Regex.Replace(input, @”]*object[^>]*>”, “o&#98jec&$58”, RegexOptions.IgnoreCase);//攻击方式 注意,这样过滤后将无法使用FLASH
/*各种事件过滤*/
input = Regex.Replace(input, @”]*[\u0020]+on[A-Za-z]{3,20}[\u0020]*=[\u0020]*[^>]*>”, “Js Event”, RegexOptions.IgnoreCase);//
input = input.Replace(“‘”, “‘”);//单引号防止SQL注入
input = Regex.Replace(input, @”script”, “Script”, RegexOptions.IgnoreCase);//防止脚本攻击
input = Regex.Replace(input, @”frame”, “frame”, RegexOptions.IgnoreCase);//防止iframe 挂马
input = Regex.Replace(input, @”form”, “form”, RegexOptions.IgnoreCase);//禁止表单提交
input = Regex.Replace(input, @”meta”, “meta”, RegexOptions.IgnoreCase);//防止用使meta跳转到非法网页
return input;
}

补充一下,过滤千万不要把字符串过虑成空,这样同样存在安来源gaodai$ma#com搞$$代**码网全问题,必须过虑成另外一个字符串,比如过滤你好,那么用户可以构建这样一个字符“你你好好”,通过Replace(“你好”,””)之后,输出的结果,我不说大家也知道!
另外,这里是考虑了支持HTML的情况,所以没有直接过虑尖括号!

以上就是Asp.net之数据过滤浅析的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Asp.net之数据过滤浅析
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址