如何實現一個php框架系列文章【5】安全處理輸入

来源:http://www.cnblogs.com/yyluming/archive/2016/02/16/5193471.html
-Advertisement-
Play Games

所有的外部輸入參數都應該檢查合法性。 未正確處理輸入數據將可能導致sql註入等漏洞。 框架提供系列函數來取$_REQUEST中的值 requestInt requestString requestFloat requestBool ps:註意$_REQUEST中變數類型可能會是數組 如請求為 ?i[


所有的外部輸入參數都應該檢查合法性。

未正確處理輸入數據將可能導致sql註入等漏洞。

 

框架提供系列函數來取$_REQUEST中的值

requestInt

requestString

requestFloat

requestBool

 

ps:註意$_REQUEST中變數類型可能會是數組

如請求為 ?i[]=1,那麼$_REQUEST['i'] 的值為array(1)

做校驗的時候要考慮全面以防止php warning信息泄露

 

 

另外再介紹一下kv json格式的數據校驗。

有時為了在項目中保留一定擴展性,會使用json格式的數據,這種數據又該如何校驗呢。

 

//校驗鍵值形式{k1:v1, k2:v2, k3:v3 ...}的json數據,可以對每一對kv進行校驗

requestKvJson

 

 

 

 

部分實現代碼

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 //校驗整數,失敗返回$default function checkInt($var$default = 0) {     return  is_numeric($var) ? intval($var, (strncasecmp($var'0x', 2) == 0 || strncasecmp($var'-0x', 3) == 0) ? 16 : 10) : $default; }   //校驗字元串 $check為正則表達式 function checkString($var$check ''$default '') {     if (!is_string($var)) {         if(is_numeric($var)) {             $var = (string)$var;         }         else {             return $default;         }     }     if ($check) {          return (preg_match($check$var$ret) ? $ret[1] : $default);     }       return $var; }   /*     校驗kv json,     如果想要一個這樣的數據{id:1, 'type':'single_text', 'required': true, 'desc':'this is a text'}     那麼$desc可以這樣寫     array(    array('id', 'Int'),    array('type', 'string', PATTERN_NORMAL_STRING),    array('required', 'Bool', false),    array('desc', 'string', PATTERN_NORMAL_STRING), )) */ function checkKvJson($var$desc array()) {     if(is_string($var)) {         $var = json_decode($var, true);     }     if(!$var || !is_array($var)) {         return array();     }       if($desc)     foreach($desc as $d) {           if(!isset($var[$d[0]])) {             return array();         }           $ps array_slice($d, 2);         array_unshift($ps$var[$d[0]]);         $var[$d[0]] = call_user_func_array('check'.$d[1], $ps);         if($var[$d[0]] === false && strcasecmp($d[1], 'Bool')) {             return array();         }     }       return $var; }

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 註:本文是【ASP.NET Identity系列教程】的第三篇。本系列教程詳細、完整、深入地介紹了微軟的ASP.NET Identity技術,描述瞭如何運用ASP.NET Identity實現應用程式的用戶管理,以及實現應用程式的認證與授權等相關技術,譯者希望本系列教程能成為掌握ASP.NET Id...
  • 需要調用win32api,winform、wpf通用 [DllImport("user32.dll")] public static extern bool GetCursorPos(out POINT lpPoint); [StructLayout(LayoutKind.Sequential)]
  • 在本文中,我們將通過一個簡單的處理來記錄在我們的網站中的錯誤和異常。我們這樣操作,每當遇到程式錯誤時,將使用者導航到一個單獨的頁面,同時錯誤將被記錄到伺服器上的一個文本文件,每當錯誤發生時,我們將以日誌的形式每天記錄。 首先,我先寫一個靜態方法用於將錯誤信息記錄到文本文件,這裡是將錯誤信息記錄到服務
  • 註釋 •#語句 •<# 語句 #> 變數 •命名法則 $ 做為首碼 •使用字母、數字、下劃線均可 •查看所有變數 Get-ChildItem variable:或Get-Varialbe •獲取作用域變數Get-Variable –Scope [Local|Global] •實例化對象 $dt=Ne
  • <MediaElement x:Name="myGif" MediaEnded="myGif_MediaEnded" UnloadedBehavior="Manual" Source="file://C:\waiting.GIF" LoadedBehavior="Play" Stretch="Non
  • ThinkPHP3.2.3 Page.class.php文件源碼 <?php // +---------------------------------------------------------------------- // | ThinkPHP [ WE CAN DO IT JUST TH
  • I/O類使用 由於在IO操作中,需要使用的數據源有很多,作為一個IO技術的初學者,從讀寫文件開始學習IO技術是一個比較好的選擇。因為文件是一種常見的數據源,而且讀寫文件也是程式員進行IO編程的一個基本能力。本章IO類的使用就從讀寫文件開始。 1 文件操作 文件(File)是 最常見的數據源之一,在程
  • Java學習筆記 類型1.1:類的相關 Tags: 編程,Java 類之間關係 代理例子查看《Java編程思想》中的P131。簡單來說,代理就是組合之後,對組合進來的類的方法進行封裝(不是重寫,而是在函數體內調用組合進來類的對應的"同名"方法。)。 類訪問許可權 |訪問修飾符| 同類 | 同包 |不同
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...