拡張可能な PHP 検証クラス。 クラス内のさまざまな検証を独自に調整して実装できます。 これが現在の基本的な実装方法です。 ルールを追加する必要がある場合は、メソッドを直接定義します。メソッド名がルール名になります。詳しくはご利用方法をご確認ください。
- require_once('./Validator.class.php');
- $data = array(
- 'ニックネーム' => 'heno' ,
- '本名' => 'スティーブン',
- '年齢' = > 25,
- 'モバイル' => '1521060426');
-
- $validator = 新しい Validator($data);
-
- $validator->setRule('ニックネーム', '必須');
- $validator- >setRule('realname', array('length' => array(1,6), 'required'));
- $validator->setRule('age', array('required', 'digit' ));
- $validator->setRule('mobile', array('mobile'));
- $result = $validator->validate();
-
- var_dump($result);
- var_dump($validator- >getResultInfo());
コードをコピー
- /**
- * Validator データ検証クラス
- * @package library
- * @category library
- * @author Steven
- * @version 1.0
- */
- /**
- * Validator データ検証クラス
- * @package library
- * @category library
- * @author Steven
- * @version 1.0
- */
- class Validator {
- /**
- * 検証されるデータ
- * @var 配列
- */
- private $_data;
- / **
- * 検証ルール
- * @var 配列
- */
- private $_ruleList = null;
- /**
- * 検証結果
- * @var bool
- */
- private $_result = null;
- /**
- * 検証データ情報
- * @var 配列
- */
- private $_resultInfo = array();
- /**
- * コンストラクター
- * @param array $data 検証するデータ
- */
- public function __construct($data = null)
- {
- if ($data) {
- $this->_data = $data;
- }
- }
-
- /**
- * 検証ルールを設定します
- * @param string $var with検証項目キー
- * @parammixed $rule 検証ルール
- * @return void
- */
- public function setRule($var, $rule)
- {
- $this->_ruleList[$var] = $rule;
- }
-
- /**
- * 检验数据
- * @param array $data
- *
</li>
<li> * $data = array('nickname' => 'heno' , 'realname' => 'steven', 'age' => 25);</li>
<li> * $validator = 新しい Validator($data);</li>
<li> * $validator->setRule('ニックネーム', '必須');</li>
<li> * $validator->setRule('実名', array('長さ) ' => array(1,4), 'required'));</li>
<li> * $validator->setRule('age', array('required', 'digit'));</li>
<li> * $result = $validator- >validate();</li>
<li> * var_dump($validator->getResultInfo());</li>
<li> *
- * @return bool
- */
- public function validate($ data = null)
- {
- $result = true;
-
- /* 検証ルールが設定されていない場合は、直接 true を返します */
- if ($this->_ruleList === null || !count($this-> ; _ruleList)) {
- return $result;
- }
-
- /* ルールが設定されている場合は、ルールを 1 つずつ確認します*/
- foreach ($this->_ruleList as $ruleKey => $ruleItem) {
-
- / * 検証ルールが単一ルールの場合*/
- if (!is_array($ruleItem)) {
- $ruleItem = トリム($ruleItem);
- if (method_exists($this, $ruleItem)) {
-
- /* 検証データ、検証結果を保存*/
- $tmpResult = $this->$ruleItem($ruleKey);
- if (!$tmpResult) {
- $this->_resultInfo[$ruleKey][$ruleItem] = $tmpResult;
- $result = false;
- }
- }
- continue;
- }
-
- /* 複数の検証ルールがあります*/
- foreach ($ruleItem as $ruleItemKey => $rule) {
-
- if (! is_array($rule)) {
- $rule = trim($rule);
- if (method_exists($this, $rule)) {
-
- /* データを検証し、結果セットを設定*/
- $tmpResult = $this-> ;$ rules($ruleKey);
- if (!$tmpResult) {
- $this->_resultInfo[$ruleKey][$rule] = $tmpResult;
- $result = false;
- }
- }
- } else {
- if (method_exists($this, $ruleItemKey)) {
-
- /* データを検証し、結果セットを設定*/
- $tmpResult = $this->$ruleItemKey($ruleKey, $rule);
- if (!$tmpResult) {
- $this->_resultInfo[$ruleKey][$ruleItemKey] = $tmpResult;
- $result = false;
- }
- }
- }
- }
- }
-
- return $result;
- }
-
- /**
- * 検証結果データを取得
- * @return [type] [description]
- */
- public function getResultInfo()
- {
- return $this->_resultInfo;
- }
-
- /**
- * 検証必須パラメーター
- * @param string $varName 検証項目
- * @return bool
- */
- public function required($varName)
- {
- $result = false;
- if (is_array($this->_data) && isset($this->_data[$varName])) {
- $result = true;
- }
- return $result;
- }
-
-
- /**
- * パラメーターの長さを確認します
- *
- * @param string $varName 項目を確認します
- * @param array $lengthData array($minLen, $maxLen)
- * @return bool
- */
- public function length($varName, $lengthData)
- {
- $result = true;
-
- /* この項目が設定されていない場合、デフォルトは検証に合格します*/
- if ($this->required( $varName )) {
- $varLen = mb_strlen($this->_data[$varName]);
- $minLen = $lengthData[0];
- $maxLen = $lengthData[1];
- if ($varLen < $minLen || $varLen > $maxLen) {
- $result = true;
- }
- }
- return $result;
- }
-
-
- /**
- * 確認メール
- * @param string $varName 確認項目
- * @return bool
- */
- public function email($varName)
- {
- $result = true;
-
- /* この項目が設定されていない場合、デフォルトは検証に合格します*/
- if ($this - >required($varName)) {
- $email = trim($this->_data[$varName]);
- if (preg_match('/^[-w]+?@[-w.]+? $ /', $email)) {
- $result = false;
- }
- }
- return $result;
- }
-
- /**
- * 携帯電話を確認します
- * @param string $varName 確認項目
- * @return bool
- */
- public function mobile($varName)
- {
- $result = true ;
-
- /* この項目が設定されていない場合、デフォルトは検証に合格します*/
- if ($this->required($varName)) {
- $mobile = trim($this->_data[$varName ]) ;
- if (!preg_match('/^1[3458]d{10}$/', $mobile)) {
- $result = false;
- }
- }
-
- return $result;
- }
-
- / **
- * チェックパラメータは数値です
- * @param string $varName check item
- * @return bool
- */
- public function digit($varName)
- {
- $result = false;
- if ($this->required($varName) && is_numeric($this->_data[$varName]) ) {
- $result = true;
- }
- return $result;
- }
-
-
- /**
- * 検証パラメータはIDカードです
- * @param string $varName検証項目
- * @return bool
- */
- パブリック関数 ID($ID)
- {
-
- }
-
-
- /**
- * 検証パラメータは URL です
- * @param string $varName 検証項目
- * @return bool
- */
- public function url($url)
- {
- $result = true;
-
- /* この項目が設定されていない場合、デフォルトは検証に合格します*/
- if ($this->required($varName)) {
- $ url = トリム($this->_data[$varName]);
- if(!preg_match('/^(http[s]?::)?w+?(.w+?)$/', $ url)) {
- $result = false;
- }
- }
- return $result;
- }
- }
- ?>
-
コードをコピー
|