You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							174 lines
						
					
					
						
							5.1 KiB
						
					
					
				
			
		
		
	
	
							174 lines
						
					
					
						
							5.1 KiB
						
					
					
				<?php | 
						|
/** | 
						|
 * @link http://www.yiiframework.com/ | 
						|
 * @copyright Copyright (c) 2008 Yii Software LLC | 
						|
 * @license http://www.yiiframework.com/license/ | 
						|
 */ | 
						|
 | 
						|
namespace yii\validators; | 
						|
 | 
						|
/** | 
						|
 * StringValidator validates that the attribute value is of certain length. | 
						|
 * | 
						|
 * Note, this validator should only be used with string-typed attributes. | 
						|
 * | 
						|
 * @author Qiang Xue <qiang.xue@gmail.com> | 
						|
 * @since 2.0 | 
						|
 */ | 
						|
class StringValidator extends Validator | 
						|
{ | 
						|
	/** | 
						|
	 * @var integer maximum length. Defaults to null, meaning no maximum limit. | 
						|
	 */ | 
						|
	public $max; | 
						|
	/** | 
						|
	 * @var integer minimum length. Defaults to null, meaning no minimum limit. | 
						|
	 */ | 
						|
	public $min; | 
						|
	/** | 
						|
	 * @var integer exact length. Defaults to null, meaning no exact length limit. | 
						|
	 */ | 
						|
	public $is; | 
						|
	/** | 
						|
	 * @var string user-defined error message used when the value is not a string | 
						|
	 */ | 
						|
	public $message; | 
						|
	/** | 
						|
	 * @var string user-defined error message used when the length of the value is smaller than [[min]]. | 
						|
	 */ | 
						|
	public $tooShort; | 
						|
	/** | 
						|
	 * @var string user-defined error message used when the length of the value is greater than [[max]]. | 
						|
	 */ | 
						|
	public $tooLong; | 
						|
	/** | 
						|
	 * @var string user-defined error message used when the length of the value is not equal to [[is]]. | 
						|
	 */ | 
						|
	public $notEqual; | 
						|
	/** | 
						|
	 * @var boolean whether the attribute value can be null or empty. Defaults to true, | 
						|
	 * meaning that if the attribute is empty, it is considered valid. | 
						|
	 */ | 
						|
	public $allowEmpty = true; | 
						|
	/** | 
						|
	 * @var mixed the encoding of the string value to be validated (e.g. 'UTF-8'). | 
						|
	 * This property is used only when mbstring PHP extension is enabled. | 
						|
	 * The value of this property will be used as the 2nd parameter of the | 
						|
	 * mb_strlen() function. If this property is not set, the application charset | 
						|
	 * will be used. If this property is set false, then strlen() will be used even | 
						|
	 * if mbstring is enabled. | 
						|
	 */ | 
						|
	public $encoding; | 
						|
 | 
						|
	/** | 
						|
	 * Validates the attribute of the object. | 
						|
	 * If there is any error, the error message is added to the object. | 
						|
	 * @param \yii\base\Model $object the object being validated | 
						|
	 * @param string $attribute the attribute being validated | 
						|
	 */ | 
						|
	public function validateAttribute($object, $attribute) | 
						|
	{ | 
						|
		$value = $object->$attribute; | 
						|
		if ($this->allowEmpty && $this->isEmpty($value)) { | 
						|
			return; | 
						|
		} | 
						|
 | 
						|
		if (!is_string($value)) { | 
						|
			$message = ($this->message !== null) ? $this->message : \Yii::t('yii|{attribute} must be a string.'); | 
						|
			$this->addError($object, $attribute, $message); | 
						|
			return; | 
						|
		} | 
						|
 | 
						|
		if (function_exists('mb_strlen') && $this->encoding !== false) { | 
						|
			$length = mb_strlen($value, $this->encoding ? $this->encoding : \Yii::$app->charset); | 
						|
		} else { | 
						|
			$length = strlen($value); | 
						|
		} | 
						|
 | 
						|
		if ($this->min !== null && $length < $this->min) { | 
						|
			$message = ($this->tooShort !== null) ? $this->tooShort : \Yii::t('yii|{attribute} is too short (minimum is {min} characters).'); | 
						|
			$this->addError($object, $attribute, $message, array('{min}' => $this->min)); | 
						|
		} | 
						|
		if ($this->max !== null && $length > $this->max) { | 
						|
			$message = ($this->tooLong !== null) ? $this->tooLong : \Yii::t('yii|{attribute} is too long (maximum is {max} characters).'); | 
						|
			$this->addError($object, $attribute, $message, array('{max}' => $this->max)); | 
						|
		} | 
						|
		if ($this->is !== null && $length !== $this->is) { | 
						|
			$message = ($this->notEqual !== null) ? $this->notEqual : \Yii::t('yii|{attribute} is of the wrong length (should be {length} characters).'); | 
						|
			$this->addError($object, $attribute, $message, array('{length}' => $this->is)); | 
						|
		} | 
						|
	} | 
						|
 | 
						|
	/** | 
						|
	 * Returns the JavaScript needed for performing client-side validation. | 
						|
	 * @param \yii\base\Model $object the data object being validated | 
						|
	 * @param string $attribute the name of the attribute to be validated. | 
						|
	 * @return string the client-side validation script. | 
						|
	 */ | 
						|
	public function clientValidateAttribute($object, $attribute) | 
						|
	{ | 
						|
		$label = $object->getAttributeLabel($attribute); | 
						|
		$value = $object->$attribute; | 
						|
 | 
						|
		if (($notEqual = $this->notEqual) === null) { | 
						|
			$notEqual = \Yii::t('yii|{attribute} is of the wrong length (should be {length} characters).'); | 
						|
		} | 
						|
		$notEqual = strtr($notEqual, array( | 
						|
			'{attribute}' => $label, | 
						|
			'{value}' => $value, | 
						|
			'{length}' => $this->is, | 
						|
		)); | 
						|
 | 
						|
		if (($tooShort = $this->tooShort) === null) { | 
						|
			$tooShort = \Yii::t('yii|{attribute} is too short (minimum is {min} characters).'); | 
						|
		} | 
						|
		$tooShort = strtr($tooShort, array( | 
						|
			'{attribute}' => $label, | 
						|
			'{value}' => $value, | 
						|
			'{min}' => $this->min, | 
						|
		)); | 
						|
 | 
						|
		if (($tooLong = $this->tooLong) === null) { | 
						|
			$tooLong = \Yii::t('yii|{attribute} is too long (maximum is {max} characters).'); | 
						|
		} | 
						|
		$tooLong = strtr($tooLong, array( | 
						|
			'{attribute}' => $label, | 
						|
			'{value}' => $value, | 
						|
			'{max}' => $this->max, | 
						|
		)); | 
						|
 | 
						|
		$js = ''; | 
						|
		if ($this->min !== null) { | 
						|
			$js .= " | 
						|
if(value.length< {$this->min}) { | 
						|
	messages.push(" . json_encode($tooShort) . "); | 
						|
} | 
						|
"; | 
						|
		} | 
						|
		if ($this->max !== null) { | 
						|
			$js .= " | 
						|
if(value.length> {$this->max}) { | 
						|
	messages.push(" . json_encode($tooLong) . "); | 
						|
} | 
						|
"; | 
						|
		} | 
						|
		if ($this->is !== null) { | 
						|
			$js .= " | 
						|
if(value.length!= {$this->is}) { | 
						|
	messages.push(" . json_encode($notEqual) . "); | 
						|
} | 
						|
"; | 
						|
		} | 
						|
 | 
						|
		if ($this->allowEmpty) { | 
						|
			$js = " | 
						|
if($.trim(value)!='') { | 
						|
	$js | 
						|
} | 
						|
"; | 
						|
		} | 
						|
 | 
						|
		return $js; | 
						|
	} | 
						|
} | 
						|
 | 
						|
 |