CFileValidator
鍖 | system.validators |
---|---|
缁ф壙 | class CFileValidator » CValidator » CComponent |
婧愯嚜 | 1.0 |
鐗堟湰 | $Id: CFileValidator.php 3491 2011-12-17 05:17:57Z jefftulsa $ |
婧愮爜 | framework/validators/CFileValidator.php |
瀹冧娇鐢ㄦā鍨嬬被鐨勫睘鎬у悕妫绱笂浼犳枃浠剁殑淇℃伅锛岀劧鍚庢楠岃繖涓 鏂囦欢鏄惁宸茶鎴愬姛涓婁紶锛屼笂浼犳枃浠剁殑澶у皬鏄惁鏈秴杩囬檺鍒讹紝 涓婁紶鏂囦欢鐨勭被鍨嬫槸鍚﹁鍏佽銆
濡傛灉姝ゅ睘鎬т箣鍓嶆湭琚祴鍊硷紝姝ら獙璇佸櫒灏嗗皾璇曟彁鍙栦笂浼犵殑鏁版嵁銆 璇锋敞鎰忥細濡傛灉浣跨敤浜嗚〃鏍煎紡杈撳叆锛屾鍔ㄤ綔灏嗕笉浼氳瀹屾垚锛
foreach($models as $i=>$model) $model->attribute = CUploadedFile::getInstance($model, "[$i]attribute");璇锋敞鎰忥細浣犲繀椤讳娇鐢CUploadedFile::getInstances 鏉ュ畬鎴愬鏂囦欢涓婁紶銆
褰撳湪涓涓椿鍔ㄨ褰曚腑浣跨敤CFileValidator锛岄氬父浼氫娇鐢ㄧ被浼间笅闈㈢殑浠g爜锛
if($model->save()) { // single upload $model->attribute->saveAs($path); // multiple upload foreach($model->attribute as $file) $file->saveAs($path); }
浣犲彲浠ヤ娇鐢CFileValidator鏉ラ獙璇佹枃浠剁殑灞炴с
闄や簡浣跨敤message灞炴ф潵璁剧疆鑷畾涔夐敊璇彁绀轰俊鎭箣澶栵紝 鏍规嵁涓嶅悓鐨勯獙璇佹儏鏅ā寮忥紝浣犺繕鍙互涓篊FileValidator璁剧疆涓浜涳紝 涓嶅悓鐨勮嚜瀹氫箟閿欒鎻愮ず淇℃伅銆傚鏋滀笂浼犳枃浠跺お澶э紝浣犲彲浠ヤ娇鐢 tooLarge灞炴ф潵瀹氫箟閿欒鎻愮ず淇℃伅銆傜被浼煎湴鏈tooSmall锛 wrongType鍜tooMany銆傝嚜瀹氫箟鐨勯敊璇彁绀轰俊鎭 鍙互鍖呮嫭鍗犱綅绗︼紝鍗犱綅绗﹀皢琚疄闄呭唴瀹规浛鎹€傞櫎浜嗘墍鏈夐獙璇佸櫒鍧 鍙瘑鍒殑鈥渰attribute}鈥濆崰浣嶇锛堝弬瑙CValidator锛夊锛 CFileValidator杩樺厑璁告寚瀹氫笅鍒楀崰浣嶇锛
鍏叡灞炴
灞炴 | 绫诲瀷 | 鎻忚堪 | 瀹氫箟鍦 |
---|---|---|---|
allowEmpty | boolean | 姝ゅ睘鎬ф槸鍚﹂渶瑕佷笂浼犱竴涓枃浠躲 榛樿鍊兼槸false锛岃〃绀洪渶瑕佷笂浼犱竴涓枃浠躲 | CFileValidator |
attributes | array | 闇瑕佽楠岃瘉鐨勫睘鎬х殑鍒楄〃銆 | CValidator |
builtInValidators | array | 鍐呯疆楠岃瘉鍣ㄥ垪琛 (name=>class) | CValidator |
enableClientValidation | boolean | 鏄惁鎵ц瀹㈡埛绔獙璇併傞粯璁ゅ间负true銆 鍙傝CActiveForm::enableClientValidation浠ヤ簡瑙f洿澶氬叧浜庡鎴风楠岃瘉鐨勭粏鑺傘 | CValidator |
maxFiles | integer | 缁欏畾灞炴у彲澶勭悊鐨勬渶澶ф枃浠舵暟銆 榛樿鍊兼槸1锛岃〃绀哄崟涓枃浠朵笂浼犮傞氳繃璁剧疆涓涓緝楂樼殑鏁板硷紝 鍙互杩涜澶氭枃浠朵笂浼犮 | CFileValidator |
maxSize | integer | 涓婁紶鏂囦欢鍏佽鐨勬渶澶у瓧鑺傛暟銆 榛樿鍊间负null锛岃〃绀轰笉闄愬埗銆 娉ㄦ剰锛氬厑璁哥殑鏈澶у瓧鑺傛暟涔熷悓鏃跺彈 'upload_max_filesize' INI 璁剧疆鍊 鍜 'MAX_FILE_SIZE' 闅愯棌瀛楁鍊肩殑褰卞搷銆 | CFileValidator |
message | string | 鐢ㄦ埛鑷畾涔夌殑閿欒鎻愮ず淇℃伅銆備笉鍚岀殑楠岃瘉鍣ㄥ彲浠ュ湪璇ヤ俊鎭腑 瀹氫箟鍚勭鍗犱綅绗︼紙灏嗚瀹為檯鍊兼浛鎹級銆傚崰浣嶇鈥渰attribute}鈥濆彲浠ヨ鎵鏈 楠岃瘉鍣ㄨ瘑鍒紝瀹冧細琚娇鐢ㄥ睘鎬х殑鏍囩鏉ユ浛鎹€ | CValidator |
minSize | integer | 涓婁紶鏂囦欢鍏佽鐨勬渶灏忓瓧鑺傛暟銆 榛樿鍊间负null锛岃〃绀轰笉闄愬埗銆 | CFileValidator |
on | array | 楠岃瘉鍣ㄥ皢琚簲鐢ㄥ埌鐨勬儏鏅ā寮忕殑鍒楄〃銆 鏁扮粍鐨勯敭-鍊奸兘鏄儏鏅ā寮忕殑鍚嶇О銆 | CValidator |
safe | boolean | 杩涜鏁村潡璧嬪兼槸鏄惁鑰冭檻姝ら獙璇佸櫒涓垪鍑虹殑灞炴х殑瀹夊叏鎬с 榛樿鍊间负true銆 | CValidator |
skipOnError | boolean | 濡傛灉褰撳墠灞炴у凡缁忓瓨鍦ㄩ獙璇侀敊璇紝杩欎釜楠岃瘉瑙勫垯 鏄惁璺宠繃銆傞粯璁ゅ兼槸false銆 | CValidator |
tooLarge | string | 涓婁紶鏂囦欢澶ぇ鐨勯敊璇彁绀轰俊鎭 | CFileValidator |
tooMany | string | 涓婁紶鏂囦欢鏁拌秴杩囬檺鍒剁殑 閿欒鎻愮ず淇℃伅銆 | CFileValidator |
tooSmall | string | 涓婁紶鏂囦欢澶皬鐨勯敊璇彁绀轰俊鎭 | CFileValidator |
types | mixed | 鍏佽琚笂浼犵殑鏂囦欢鎵╁睍鍚嶇殑鍒楄〃銆 鍙互鏄竴涓暟缁勶紝涔熷彲浠ユ槸涓涓敱琚厑璁哥殑鏂囦欢鎵╁睍鍚 缁勬垚鐨勫瓧绗︿覆锛屾墿灞曞悕涔嬮棿浣跨敤绌烘牸鎴栭楀彿鍒嗛殧 锛堜緥濡傦細"gif, jpg"锛夈傛枃浠舵墿灞曞悕鏄ぇ灏忓啓鏁忔劅鐨勩 榛樿鍊兼槸null锛岃〃绀烘墍鏈夌被鍨嬮兘琚厑璁搞 | CFileValidator |
wrongType | string | 涓婁紶鏂囦欢鐨勬墿灞曞悕涓嶅寘鍚湪extensions 涓殑閿欒鎻愮ず淇℃伅銆 | CFileValidator |
鍏叡鏂规硶
鍙椾繚鎶ゆ柟娉
鏂规硶 | 鎻忚堪 | 瀹氫箟鍦 |
---|---|---|
addError() | 娣诲姞鍏充簬鎸囧畾灞炴х殑涓涓敊璇彁绀轰俊鎭埌娲诲姩璁板綍涓 | CValidator |
emptyAttribute() | 閫氱煡缁堢鐢ㄦ埛鍑虹幇浜嗙┖鐧藉睘鎬х殑閿欒 | CFileValidator |
getSizeLimit() | 杩斿洖鍏佽鐨勪笂浼犳枃浠舵渶澶у瓧鑺傛暟 | CFileValidator |
isEmpty() | 妫娴嬬粰瀹氬兼槸鍚︿负绌恒 | CValidator |
validateAttribute() | 涓轰紶鍏ュ璞$殑灞炴ц祴鍊硷紝鐒跺悗浣跨敤validateFile杩涜楠岃瘉銆 | CFileValidator |
validateFile() | 鍐呴儴楠岃瘉涓涓枃浠跺璞° | CFileValidator |
灞炴ц缁
姝ゅ睘鎬ф槸鍚﹂渶瑕佷笂浼犱竴涓枃浠躲 榛樿鍊兼槸false锛岃〃绀洪渶瑕佷笂浼犱竴涓枃浠躲
缁欏畾灞炴у彲澶勭悊鐨勬渶澶ф枃浠舵暟銆 榛樿鍊兼槸1锛岃〃绀哄崟涓枃浠朵笂浼犮傞氳繃璁剧疆涓涓緝楂樼殑鏁板硷紝 鍙互杩涜澶氭枃浠朵笂浼犮
涓婁紶鏂囦欢鍏佽鐨勬渶澶у瓧鑺傛暟銆 榛樿鍊间负null锛岃〃绀轰笉闄愬埗銆 娉ㄦ剰锛氬厑璁哥殑鏈澶у瓧鑺傛暟涔熷悓鏃跺彈 'upload_max_filesize' INI 璁剧疆鍊 鍜 'MAX_FILE_SIZE' 闅愯棌瀛楁鍊肩殑褰卞搷銆
鍙傝
涓婁紶鏂囦欢鍏佽鐨勬渶灏忓瓧鑺傛暟銆 榛樿鍊间负null锛岃〃绀轰笉闄愬埗銆
鍙傝
杩斿洖鍏佽鐨勪笂浼犳枃浠舵渶澶у瓧鑺傛暟 鏈澶у瓧鑺傛暟鐢变互涓嬩笁涓洜绱犲叡鍚屽喅瀹氾細
- php.ini閰嶇疆鏂囦欢涓殑鈥渦pload_max_filesize鈥濊缃
- 闅愯棌瀛楁鈥淢AX_FILE_SIZE鈥
- maxSize
涓婁紶鏂囦欢澶ぇ鐨勯敊璇彁绀轰俊鎭
鍙傝
涓婁紶鏂囦欢鏁拌秴杩囬檺鍒剁殑 閿欒鎻愮ず淇℃伅銆
涓婁紶鏂囦欢澶皬鐨勯敊璇彁绀轰俊鎭
鍙傝
鍏佽琚笂浼犵殑鏂囦欢鎵╁睍鍚嶇殑鍒楄〃銆 鍙互鏄竴涓暟缁勶紝涔熷彲浠ユ槸涓涓敱琚厑璁哥殑鏂囦欢鎵╁睍鍚 缁勬垚鐨勫瓧绗︿覆锛屾墿灞曞悕涔嬮棿浣跨敤绌烘牸鎴栭楀彿鍒嗛殧 锛堜緥濡傦細"gif, jpg"锛夈傛枃浠舵墿灞曞悕鏄ぇ灏忓啓鏁忔劅鐨勩 榛樿鍊兼槸null锛岃〃绀烘墍鏈夌被鍨嬮兘琚厑璁搞
涓婁紶鏂囦欢鐨勬墿灞曞悕涓嶅寘鍚湪extensions 涓殑閿欒鎻愮ず淇℃伅銆
鏂规硶璇︾粏
protected void emptyAttribute(CModel $object, string $attribute)
| ||
$object | CModel | 闇瑕侀獙璇佺殑瀵硅薄 |
$attribute | string | 闇瑕侀獙璇佺殑灞炴 |
protected function emptyAttribute($object, $attribute)
{
if(!$this->allowEmpty)
{
$message=$this->message!==null?$this->message : Yii::t('yii','{attribute} cannot be blank.');
$this->addError($object,$attribute,$message);
}
}
閫氱煡缁堢鐢ㄦ埛鍑虹幇浜嗙┖鐧藉睘鎬х殑閿欒
protected integer getSizeLimit()
| ||
{return} | integer | 涓婁紶鏂囦欢鐨勫瓧鑺傛暟銆 |
protected function getSizeLimit()
{
$limit=ini_get('upload_max_filesize');
$limit=$this->sizeToBytes($limit);
if($this->maxSize!==null && $limit>0 && $this->maxSize<$limit)
$limit=$this->maxSize;
if(isset($_POST['MAX_FILE_SIZE']) && $_POST['MAX_FILE_SIZE']>0 && $_POST['MAX_FILE_SIZE']<$limit)
$limit=$_POST['MAX_FILE_SIZE'];
return $limit;
}
杩斿洖鍏佽鐨勪笂浼犳枃浠舵渶澶у瓧鑺傛暟 鏈澶у瓧鑺傛暟鐢变互涓嬩笁涓洜绱犲叡鍚屽喅瀹氾細
- php.ini閰嶇疆鏂囦欢涓殑鈥渦pload_max_filesize鈥濊缃
- 闅愯棌瀛楁鈥淢AX_FILE_SIZE鈥
- maxSize
protected void validateAttribute(CModel $object, string $attribute)
| ||
$object | CModel | 闇瑕侀獙璇佺殑瀵硅薄 |
$attribute | string | 闇瑕侀獙璇佺殑灞炴 |
protected function validateAttribute($object, $attribute)
{
if($this->maxFiles > 1)
{
$files=$object->$attribute;
if(!is_array($files) || !isset($files[0]) || !$files[0] instanceof CUploadedFile)
$files = CUploadedFile::getInstances($object, $attribute);
if(array()===$files)
return $this->emptyAttribute($object, $attribute);
if(count($files) > $this->maxFiles)
{
$message=$this->tooMany!==null?$this->tooMany : Yii::t('yii', '{attribute} cannot accept more than {limit} files.');
$this->addError($object, $attribute, $message, array('{attribute}'=>$attribute, '{limit}'=>$this->maxFiles));
}
else
foreach($files as $file)
$this->validateFile($object, $attribute, $file);
}
else
{
$file = $object->$attribute;
if(!$file instanceof CUploadedFile)
{
$file = CUploadedFile::getInstance($object, $attribute);
if(null===$file)
return $this->emptyAttribute($object, $attribute);
}
$this->validateFile($object, $attribute, $file);
}
}
涓轰紶鍏ュ璞$殑灞炴ц祴鍊硷紝鐒跺悗浣跨敤validateFile杩涜楠岃瘉銆 濡傛灉瀛樺湪浠讳綍楠岃瘉閿欒锛岄敊璇彁绀轰俊鎭皢琚坊鍔犲埌瀵硅薄涓
protected void validateFile(CModel $object, string $attribute, CUploadedFile $file)
| ||
$object | CModel | 闇瑕侀獙璇佺殑瀵硅薄 |
$attribute | string | 闇瑕侀獙璇佺殑灞炴 |
$file | CUploadedFile | 涓婁紶鐨勬枃浠讹紝鍩轰簬涓涓鍒欑殑闆嗗悎瀵瑰叾杩涜妫娴 |
protected function validateFile($object, $attribute, $file)
{
if(null===$file || ($error=$file->getError())==UPLOAD_ERR_NO_FILE)
return $this->emptyAttribute($object, $attribute);
else if($error==UPLOAD_ERR_INI_SIZE || $error==UPLOAD_ERR_FORM_SIZE || $this->maxSize!==null && $file->getSize()>$this->maxSize)
{
$message=$this->tooLarge!==null?$this->tooLarge : Yii::t('yii','The file "{file}" is too large. Its size cannot exceed {limit} bytes.');
$this->addError($object,$attribute,$message,array('{file}'=>$file->getName(), '{limit}'=>$this->getSizeLimit()));
}
else if($error==UPLOAD_ERR_PARTIAL)
throw new CException(Yii::t('yii','The file "{file}" was only partially uploaded.',array('{file}'=>$file->getName())));
else if($error==UPLOAD_ERR_NO_TMP_DIR)
throw new CException(Yii::t('yii','Missing the temporary folder to store the uploaded file "{file}".',array('{file}'=>$file->getName())));
else if($error==UPLOAD_ERR_CANT_WRITE)
throw new CException(Yii::t('yii','Failed to write the uploaded file "{file}" to disk.',array('{file}'=>$file->getName())));
else if(defined('UPLOAD_ERR_EXTENSION') && $error==UPLOAD_ERR_EXTENSION) // available for PHP 5.2.0 or above
throw new CException(Yii::t('yii','File upload was stopped by extension.'));
if($this->minSize!==null && $file->getSize()<$this->minSize)
{
$message=$this->tooSmall!==null?$this->tooSmall : Yii::t('yii','The file "{file}" is too small. Its size cannot be smaller than {limit} bytes.');
$this->addError($object,$attribute,$message,array('{file}'=>$file->getName(), '{limit}'=>$this->minSize));
}
if($this->types!==null)
{
if(is_string($this->types))
$types=preg_split('/[\s,]+/',strtolower($this->types),-1,PREG_SPLIT_NO_EMPTY);
else
$types=$this->types;
if(!in_array(strtolower($file->getExtensionName()),$types))
{
$message=$this->wrongType!==null?$this->wrongType : Yii::t('yii','The file "{file}" cannot be uploaded. Only files with these extensions are allowed: {extensions}.');
$this->addError($object,$attribute,$message,array('{file}'=>$file->getName(), '{extensions}'=>implode(', ',$types)));
}
}
}
鍐呴儴楠岃瘉涓涓枃浠跺璞°