校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > PHP簡單實現防止SQL注入的方法

PHP簡單實現防止SQL注入的方法

熱門標簽:長沙crm外呼系統業務 南寧高頻外呼回撥系統哪家好 離石地圖標注 電話機器人危險嗎 專業電話機器人批發商 深圳外呼系統收費 400電話辦理福州市 400電話申請方法收費 江蘇外呼電銷機器人報價

本文實例講述了PHP簡單實現防止SQL注入的方法。分享給大家供大家參考,具體如下:

方法一:execute代入參數

?php
if(count($_POST)!= 0) {
  $host = 'aaa';
  $database = 'bbb';
  $username = 'ccc';
  $password = '***';
  $num = 0;
  $pdo = new PDO("mysql:host=$host;dbname=$database", $username, $password);//創建一個pdo對象
  foreach ($_POST as $var_Key => $var_Value) {
    //獲取POST數組最大值
    $num = $num + 1;
  }
  //下標為i的數組存儲的是商品id, 下標為j數組的存儲的是此商品的庫存
  for($i=0;$i$num;$i=$i+2)
  {
    //庫存下標
    $j = $i+1;
    //判斷傳遞過來的數據合法性
    if(is_numeric(trim($_POST[$i]))  is_numeric(trim($_POST[$j]))){
      //禁用prepared statements的仿真效果
      $pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
      //查詢數據庫中是否存在該ID的商品
      //當調用 prepare() 時,查詢語句已經發送給了數據庫服務器,此時只有占位符 ? 發送過去,沒有用戶提交的數據
      $stmt = $pdo->prepare("select good_id from delphi_test_content WHERE good_id = ?");
      //當調用到 execute()時,用戶提交過來的值才會傳送給數據庫,他們是分開傳送的,兩者獨立的,SQL攻擊者沒有一點機會。
      $stmt->execute(array($_POST[$i]));
      //返回查詢結果
      $count = $stmt->rowCount();
      //如果本地數據庫存在該商品ID和庫存記錄,就更新該商品的庫存
      if($count != 0)
      {
        $stmt = $pdo->prepare("update delphi_test_content set content = ? WHERE good_id = ?");
        $stmt->execute(array($_POST[$j], $_POST[$i]));
      }
      //如果本地數據庫沒有該商品ID和庫存記錄,就新增該條記錄
      if($count == 0)
      {
        $stmt = $pdo->prepare("insert into delphi_test_content (good_id,content) values (?,?)");
        $stmt->execute(array($_POST[$i], $_POST[$j]));
      }
    }
  }
  $pdo = null;
  //關閉連接
}
?>

方法二:bindParam綁定參數

?php
if(count($_POST)!= 0) {
  $host = 'aaa';
  $database = 'bbb';
  $username = 'ccc';
  $password = '***';
  $num = 0;
  $pdo = new PDO("mysql:host=$host;dbname=$database", $username, $password);//創建一個pdo對象
  foreach ($_POST as $var_Key => $var_Value) {
    //獲取POST數組最大值
    $num = $num + 1;
  }
  //下標為i的數組存儲的是商品id, 下標為j數組的存儲的是此商品的庫存
  for($i=0;$i$num;$i=$i+2)
  {
    //庫存下標
    $j = $i+1;
    //判斷傳遞過來的數據合法性(此數據為商品編號以及庫存,嚴格來說字符串全是由數字組成的)
    if(is_numeric(trim($_POST[$i]))  is_numeric(trim($_POST[$j]))){
      //查詢數據庫中是否存在該ID的商品
      $stmt = $pdo->prepare("select good_id from delphi_test_content WHERE good_id = ?");
      $stmt->execute(array($_POST[$i]));
      $stmt->bindParam(1,$_POST[$i]);
      $stmt->execute();
      //返回查詢結果
      $count = $stmt->rowCount();
      //如果本地數據庫存在該商品ID和庫存記錄,就更新該商品的庫存
      if($count != 0)
      {
        $stmt = $pdo->prepare("update delphi_test_content set content = ? WHERE good_id = ?");
        $stmt->execute(array($_POST[$j], $_POST[$i]));
        $stmt->bindParam(1,$_POST[$j]);
        $stmt->bindParam(2,$_POST[$i]);
        $stmt->execute();
      }
      //如果本地數據庫沒有該商品ID和庫存記錄,就新增該條記錄
      if($count == 0)
      {
        $stmt = $pdo->prepare("insert into delphi_test_content (good_id,content) values (?,?)");
        $stmt->bindParam(1,$_POST[$i]);
        $stmt->bindParam(2,$_POST[$j]);
        $stmt->execute();
      }
    }
  }
  $pdo = null;
  //關閉連接
}
?>

更多關于PHP相關內容感興趣的讀者可查看本站專題:《php程序設計安全教程》、《php安全過濾技巧總結》、《PHP運算與運算符用法總結》、《PHP基本語法入門教程》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》

希望本文所述對大家PHP程序設計有所幫助。

您可能感興趣的文章:
  • php中防止SQL注入的最佳解決方法
  • PHP中防止SQL注入實現代碼
  • php防止SQL注入詳解及防范
  • 有效防止SQL注入的5種方法總結
  • 防止xss和sql注入:JS特殊字符過濾正則
  • JS代碼防止SQL注入的方法(超簡單)
  • PHP中防止SQL注入攻擊和XSS攻擊的兩個簡單方法
  • discuz的php防止sql注入函數
  • c#.net全站防止SQL注入類的代碼
  • 有效防止sql注入的方法演示

標簽:南昌 白酒營銷 興安盟 曲靖 南京 濱州 株洲 太原

巨人網絡通訊聲明:本文標題《PHP簡單實現防止SQL注入的方法》,本文關鍵詞  PHP,簡單,實現,防止,SQL,注入,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP簡單實現防止SQL注入的方法》相關的同類信息!
  • 本頁收集關于PHP簡單實現防止SQL注入的方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 桃源县| 尖扎县| 昔阳县| 苏尼特左旗| 荣昌县| 淳安县| 东平县| 车险| 咸宁市| 武山县| 天气| 电白县| 乐山市| 句容市| 公主岭市| 和顺县| 山东| 蒲城县| 南投县| 沙雅县| 台山市| 调兵山市| 常宁市| 旅游| 阳东县| 沽源县| 四子王旗| 连州市| 望谟县| 紫阳县| 江达县| 靖边县| 噶尔县| 丰都县| 博湖县| 磐安县| 石门县| 平凉市| 瑞昌市| 江北区| 周口市|