您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關php中如何使用filter_var實現參數驗證的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
先看看代碼:
<?php class Utils { /** * 主要是調用filter_var_array驗證,再擴充一個required字段來表示必填項。 * http://www.php.net/manual/zh/book.filter.php * 注意: (可以不傳,但不能傳錯) * 1.先驗證格式,有失敗的拋異常。 * 2.未傳的參數,有default的(不管是否required=1),則設置為default值。 * 示例: * $filterArr = array( * "pn" =>array( * "required" => 1, * "filter" => FILTER_VALIDATE_INT, * "options" => array( * "default" =>1, * "min_range" =>1, * ) * ) * ) */ public static function filter_param($paramArr, $filterArr){ $res = filter_var_array($paramArr, $filterArr); //參數不合法-flase, 沒傳參數-null foreach($res as $key=>$val){ //如果有驗證失敗的,拋出異常。 if(false === $val){ throw new Exception( "Utils::filter_param: failed, key=$key "); } //再判斷未傳的參數。 if( is_null($val)){ //1.如果是必填項 if($filterArr[$key]['required'] ){ if(isset($filterArr[$key]['options']['default'])){ //1.1如果有default值,則設置為default值。 $res[$key] = $filterArr[$key]['options']['default']; }else{ //1.2如果沒有default值,拋出異常。 throw new Exception( "Utils::filter_param: Do not have required param, key=$key" ); } }else{ //$res[$key]=''; //這里是默認把null值改為空值。是否有必要? } } } return $res; } }; //每個model里,都寫個checkParam函數,用來配置驗證的規則。 function checkParam($arrInput){ //1.先檢查catId $filter = array( //數字類型的,必填。只允許 0-1。 "catId" => array( "required"=>1, "filter"=>FILTER_VALIDATE_INT, "options"=>array( "min_range" =>0, "max_range" =>1, ) ), //字符串類型的,必填。長度大于1。 "title" => array( "required"=>1, "filter"=>FILTER_VALIDATE_REGEXP, "options"=>array( "regexp" =>"/^.+/", ) ), //字符串類型的,非必填。但要是填了的話,則格式必須為email。 "email" => array( "filter"=>FILTER_VALIDATE_EMAIL, ), ); $_res = Utils::filter_param($arrInput, $filter) ; } //比如這個是輸入的參數。可以試著修改這里看看效果。 $arrInput=array( 'catId'=>1, 'title'=>'xx', 'email'=>'xxxxxx.com', ); try{ $res=checkParam($arrInput); echo "驗證通過,繼續其它代碼...\n"; }catch(Exception $e){ echo 'Caught exception: ', $e->getMessage(), "\n"; } ?>
上面的代碼,可直接運行。
使用方法:
建議把filter_param放到公共函數庫中。
建議在每個model里都有個checkParam函數,專門配置驗證規則。
感謝各位的閱讀!關于“php中如何使用filter_var實現參數驗證”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。