亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

C#防SQL注入代碼的三種方法

2020-01-24 02:52:23
字體:
來源:轉載
供稿:網友

對于網站的安全性,是每個網站開發者和運營者最關心的問題。網站一旦出現漏洞,那勢必將造成很大的損失。為了提高網站的安全性,首先網站要防注入,最重要的是服務器的安全設施要做到位。

  下面說下網站防注入的幾點要素。

  一:丟棄SQL語句直接拼接,雖然這個寫起來很快很方便。

  二:如果用SQL語句,那就使用參數化,添加Param

  三:盡可能的使用存儲過程,安全性能高而且處理速度也快

  四:屏蔽SQL,javascript等注入(很是主要的),對于每個文件寫是不太可能的。所以要找到對所有文件起作用的辦法。我在網上收集了以下3種方法

  C#防SQL注入方法一

  在Web.config文件中, < appSettings>下面增加一個標簽:如下

復制代碼 代碼如下:

  < appSettings>

  < add key="safeParameters" value="OrderID-int32,CustomerEmail-email,ShippingZipcode-USzip" />

  < /appSettings>


  其中key是 < saveParameters>后面的值為"OrderId-int32"等,其中"-"前面表示參數的名稱比如:OrderId,后面的int32表示數據類型。

  C#防SQL注入方法二

  在Global.asax中增加下面一段:

復制代碼 代碼如下:

  protected void Application_BeginRequest(Object sender, EventArgs e){

  String[] safeParameters = System.Configuration.ConfigurationSettings.AppSettings["safeParameters"].ToString()。Split(',');

  for(int i= 0 ;i < safeParameters.Length; i++){

  String parameterName = safeParameters[i].Split('-')[0];

  String parameterType = safeParameters[i].Split('-')[1];

  isValidParameter(parameterName, parameterType);

  }

  }

  public void isValidParameter(string parameterName, string parameterType){

  string parameterValue = Request.QueryString[parameterName];

  if(parameterValue == null) return;

  if(parameterType.Equals("int32")){

  if(!parameterCheck.isInt(parameterValue)) Response.Redirect("parameterError.aspx");

  }

  else if (parameterType.Equals("USzip")){

  if(!parameterCheck.isUSZip(parameterValue)) Response.Redirect("parameterError.aspx");

  }

  else if (parameterType.Equals("email")){

  if(!parameterCheck.isEmail(parameterValue)) Response.Redirect("parameterError.aspx");

  }

  }


  C#防SQL注入方法三

  使用字符串過濾類

復制代碼 代碼如下:

  using System;

  namespace web.comm

  {

  /**//// < summary>

  /// ProcessRequest 的摘要說明。

  /// < /summary>

  public class ProcessRequest

  {

  public ProcessRequest()

  {

  //

  // TODO: 在此處添加構造函數邏輯

  //

  }


  SQL注入式攻擊代碼分析#region SQL注入式攻擊代碼分析
復制代碼 代碼如下:

  /**//// < summary>

  /// 處理用戶提交的請求

  /// < /summary>

  public static void StartProcessRequest()

  {

  // System.Web.HttpContext.Current.Response.Write("< script>alert('dddd');< /script>");

  try

  {

  string getkeys = "";

  //string sqlErrorPage = System.Configuration.ConfigurationSettings.AppSettings["CustomErrorPage"].ToString();

  if (System.Web.HttpContext.Current.Request.QueryString != null)

  {

  for(int i=0;i< System.Web.HttpContext.Current.Request.QueryString.Count;i++)

  {

  getkeys = System.Web.HttpContext.Current.Request.QueryString.Keys[i];

  if (!ProcessSqlStr(System.Web.HttpContext.Current.Request.QueryString[getkeys],0))

  {

  //System.Web.HttpContext.Current.Response.Redirect (sqlErrorPage+"?errmsg=sqlserver&sqlprocess=true");

  System.Web.HttpContext.Current.Response.Write("< script>alert('請勿非法提交!');history.back();< /script>");

  System.Web.HttpContext.Current.Response.End();

  }

  }

  }

  if (System.Web.HttpContext.Current.Request.Form != null)

  {

  for(int i=0;i< System.Web.HttpContext.Current.Request.Form.Count;i++)

  {

  getkeys = System.Web.HttpContext.Current.Request.Form.Keys[i];

  if (!ProcessSqlStr(System.Web.HttpContext.Current.Request.Form[getkeys],1))

  {

  //System.Web.HttpContext.Current.Response.Redirect (sqlErrorPage+"?errmsg=sqlserver&sqlprocess=true");

  System.Web.HttpContext.Current.Response.Write("< script>alert('請勿非法提交!');history.back();< /script>");

  System.Web.HttpContext.Current.Response.End();

  }

  }

  }

  }

  catch

  {

  // 錯誤處理: 處理用戶提交信息!

  }

  }

  /**//// < summary>

  /// 分析用戶請求是否正常

  /// < /summary>

  /// < param name="Str">傳入用戶提交數據< /param>

  /// < returns>返回是否含有SQL注入式攻擊代碼< /returns>

  private static bool ProcessSqlStr(string Str,int type)

  {

  string SqlStr;

  if(type == 1)

  SqlStr = "exec |insert |select |delete |update |count |chr |mid |master |truncate |char |declare ";

  else

  SqlStr = "'|and|exec|insert|select|delete|update|count|*|chr|mid|master|truncate|char|declare";

  bool ReturnValue = true;

  try

  {

  if (Str != "")

  {

  string[] anySqlStr = SqlStr.Split('|');

  foreach (string ss in anySqlStr)

  {

  if (Str.IndexOf(ss)>=0)

  {

  ReturnValue = false;

  }

  }

  }

  }

  catch

  {

  ReturnValue = false;

  }

  return ReturnValue;

  }

  #endregion

  }

  }

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
在线观看日韩欧美| 日韩少妇与小伙激情| 精品国产一区二区三区久久久| 日韩欧美亚洲综合| 国产v综合v亚洲欧美久久| 欧美天堂在线观看| 午夜精品www| 亚洲国产天堂久久综合网| 亚洲国产精品久久91精品| 欧美日本高清视频| 日韩av高清不卡| 美女精品久久久| 成人精品网站在线观看| 国产在线精品成人一区二区三区| 精品久久久精品| 中文精品99久久国产香蕉| 亚洲男人天堂2019| yellow中文字幕久久| 国产欧美精品在线| 国产精品久久综合av爱欲tv| 韩曰欧美视频免费观看| 91色在线观看| 91tv亚洲精品香蕉国产一区7ujn| 久久久亚洲国产天美传媒修理工| 日韩有码在线观看| 久久天天躁狠狠躁老女人| 欧美高清自拍一区| 欧美—级a级欧美特级ar全黄| 亚洲男人天堂2024| 欧美日韩aaaa| 亚洲精品永久免费| 中文字幕日韩在线视频| 亚洲国产欧美一区二区丝袜黑人| 国产99久久精品一区二区 夜夜躁日日躁| 久久露脸国产精品| 精品国产精品三级精品av网址| 美女999久久久精品视频| 欧美激情精品久久久久久蜜臀| 成人午夜在线观看| 国产精品99久久99久久久二8| 欧美日韩国产一区在线| 亚洲精品久久久一区二区三区| 国内精品久久久久久中文字幕| 欧美一区二区三区……| 日本免费久久高清视频| 精品日本美女福利在线观看| 日韩国产欧美精品在线| 亚洲国产成人久久| 久久69精品久久久久久国产越南| 日韩电影视频免费| 亚洲视频国产视频| 日韩少妇与小伙激情| 日本高清久久天堂| 66m—66摸成人免费视频| 国产欧美婷婷中文| 亚洲第一偷拍网| 国产精品老牛影院在线观看| 91精品国产综合久久久久久蜜臀| 国产午夜精品美女视频明星a级| 日韩成人免费视频| 亚洲欧美综合区自拍另类| 欧美性猛交xxxxx水多| 亚洲精品狠狠操| 国产精品大片wwwwww| www.日韩视频| 亚洲白拍色综合图区| 亚洲精品视频中文字幕| 992tv成人免费视频| 亚洲一区二区三区777| 久久五月天色综合| 日韩小视频在线| 欧美性猛交99久久久久99按摩| 亚洲人成电影网| 亚洲色图美腿丝袜| 国产在线视频欧美| 亚洲免费av片| 91最新国产视频| 成人久久一区二区| 亚洲一区二区三区在线视频| 成人乱色短篇合集| 欧美性xxxx极品高清hd直播| 国产精品18久久久久久首页狼| 中文字幕在线国产精品| 日本最新高清不卡中文字幕| 国产精品视频xxx| 欧美日韩人人澡狠狠躁视频| 欧美xxxx做受欧美.88| 97人人做人人爱| 欧美一区二区三区四区在线| 国产日产欧美a一级在线| 欧美黑人巨大xxx极品| 成人性教育视频在线观看| 久久国产精品电影| 欧美一性一乱一交一视频| 97精品视频在线观看| 欧美黄色片在线观看| 26uuu久久噜噜噜噜| 亚洲欧美日韩精品久久亚洲区| 久久香蕉频线观| 亚洲福利视频久久| 成人黄色免费在线观看| 日本精品久久久久影院| 日韩av电影免费观看高清| 国产精品www色诱视频| 黑人狂躁日本妞一区二区三区| 最近2019免费中文字幕视频三| 国产精品久在线观看| 狠狠干狠狠久久| 日韩精品亚洲视频| 精品欧美国产一区二区三区| 国产精品美女视频网站| 亚洲成人动漫在线播放| 夜夜嗨av一区二区三区四区| 91久久精品在线| 国产91在线高潮白浆在线观看| 一夜七次郎国产精品亚洲| 国产精品高清在线观看| 日韩精品在线观看一区| 亚洲国产精品视频在线观看| 国产精品久久久av| 欧美激情亚洲综合一区| 日韩av影片在线观看| 亚洲精品按摩视频| 97欧美精品一区二区三区| 97婷婷大伊香蕉精品视频| 国产精品老女人精品视频| 欧美美女操人视频| 色av中文字幕一区| 亚洲欧美激情在线视频| 精品国产一区二区三区久久狼黑人| 欧美做受高潮电影o| 国产欧美精品久久久| 4388成人网| 国产精品久久久久久久久久久久久| 91亚洲精品久久久| 国产视频综合在线| 夜夜嗨av一区二区三区免费区| 日韩av在线网页| 国产极品精品在线观看| 亚洲人成在线观看网站高清| 亚洲欧美一区二区三区四区| 亚洲va电影大全| 欧美午夜激情小视频| 久久久久久69| 91极品视频在线| 国产成人拍精品视频午夜网站| 高清欧美性猛交xxxx| 日韩av影视综合网| 在线电影av不卡网址| 日韩av网址在线观看| 欧美一级大胆视频| 成人在线一区二区| 蜜月aⅴ免费一区二区三区| 亚洲综合日韩中文字幕v在线| 97免费视频在线| 69影院欧美专区视频| 中文字幕精品www乱入免费视频| 国产日韩精品在线| 亚洲qvod图片区电影| 欧美老女人性生活| 日韩小视频网址| 国产精品大片wwwwww| 成人动漫网站在线观看| 亚洲天堂色网站|