欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

ASP.NET防止SQL注入的方法示例

程序员文章站 2023-11-29 21:46:40
本文实例讲述了asp.net防止sql注入的方法。分享给大家供大家参考,具体如下: 最近接手别人一个项目,发现存在sql注入漏洞,因为不想改太多代码,所以那种参数法防注入...

本文实例讲述了asp.net防止sql注入的方法。分享给大家供大家参考,具体如下:

最近接手别人一个项目,发现存在sql注入漏洞,因为不想改太多代码,所以那种参数法防注入呢我就用不着了。只能用传统的笨一点的办法了。

1、新建global.asax文件。

2、加入如下代码:

void application_beginrequest(object sender, eventargs e)
{
    bool result = false;
    if (request.requesttype.toupper() == "post")
    {
       //post方式的我就不写了。
    }
    else
    {
      result = validurlgetdata();
    }
    if (result)
    {
      response.write("您提交的数据有恶意字符!");
      response.end();
    }
}
/// <summary>
/// 获取querystring中的数据
/// </summary>
public static bool validurlgetdata()
{
    bool result = false;
    for (int i = 0; i < httpcontext.current.request.querystring.count; i++)
    {
      result = validate(httpcontext.current.request.querystring[i].tostring());
      if (result)
      {
        break;
      }//如果检测存在漏洞
    }
    return result;
}
public static string []strs = new string[] {"select","drop","exists","exec","insert","delete","update","and","or","user" };//此处我随便加了几个,大家可以多加点哈。
public static bool validate(string str)
{
    for (int i = 0; i < strs.length; i++)
    {
      if (str.indexof(strs[i]) != -1)
      {
        return true;
        break;
      }
    }
    return false;
}

更多关于asp.net相关内容感兴趣的读者可查看本站专题:《asp.net优化技巧总结》、《asp.net字符串操作技巧汇总》、《asp.net操作xml技巧总结》、《asp.net文件操作技巧汇总》、《asp.net ajax技巧总结专题》及《asp.net缓存操作技巧总结》。

希望本文所述对大家asp.net程序设计有所帮助。