當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Validator::validationError方法代碼示例

本文整理匯總了PHP中Validator::validationError方法的典型用法代碼示例。如果您正苦於以下問題:PHP Validator::validationError方法的具體用法?PHP Validator::validationError怎麽用?PHP Validator::validationError使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Validator的用法示例。


在下文中一共展示了Validator::validationError方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: validate

 /**
  * This function first gets values from mapped fields and then check these values against
  * Mollom web service and then notify callback object with the spam checking result.
  * @param Validator $validator
  * @return 	boolean		- true when Mollom confirms that the submission is ham (not spam)
  *						- false when Mollom confirms that the submission is spam 
  * 						- false when Mollom say 'unsure'. 
  *						  In this case, 'mollom_captcha_requested' session is set to true 
  *       				  so that Field() knows it's time to display captcha 			
  */
 public function validate($validator)
 {
     // Check that, if necessary, the user has given permission to check for spam
     $requireConfirmation = Config::inst()->get('AkismetSpamProtector', 'require_confirmation');
     if ($requireConfirmation && !$this->Value()) {
         $validator->validationError($this->name, _t('AkismetField.NOTIFICATIONREQUIRED', 'You must give consent to submit this content to spam detection'), "error");
         return false;
     }
     // Check result
     $isSpam = $this->getIsSpam();
     if (!$isSpam) {
         return true;
     }
     // Save error message
     $errorMessage = _t('AkismetField.SPAM', "Your submission has been rejected because it was treated as spam.");
     // If spam should be allowed, let it pass and save it for later
     if (Config::inst()->get('AkismetSpamProtector', 'save_spam')) {
         // In order to save spam but still display the spam message, we must mock a form message
         // without failing the validation
         $errors = array(array('fieldName' => $this->name, 'message' => $errorMessage, 'messageType' => 'error'));
         $formName = $this->getForm()->FormName();
         Session::set("FormInfo.{$formName}.errors", $errors);
         return true;
     } else {
         // Mark as spam
         $validator->validationError($this->name, $errorMessage, "error");
         return false;
     }
 }
開發者ID:helpfulrobot,項目名稱:tractorcow-silverstripe-akismet,代碼行數:39,代碼來源:AkismetField.php

示例2: validate

 /**
  * Validate this field as a valid hostname
  *
  * @param Validator $validator
  * @return bool
  */
 public function validate($validator)
 {
     if ($this->checkHostname($this->Value())) {
         return true;
     }
     $validator->validationError($this->getName(), _t("DomainNameField.INVALID_DOMAIN", "Invalid domain name"), "validation");
     return false;
 }
開發者ID:mikenz,項目名稱:silverstripe-simplesubsites,代碼行數:14,代碼來源:WildcardDomainField.php

示例3: validate

 /**
  * Validate this field
  *
  * @param Validator $validator
  * @return bool
  */
 public function validate($validator)
 {
     if (!is_null($this->maxLength) && mb_strlen($this->value) > $this->maxLength) {
         $validator->validationError($this->name, _t('TextField.VALIDATEMAXLENGTH', 'The value for {name} must not exceed {maxLength} characters in length', array('name' => $this->getName(), 'maxLength' => $this->maxLength)), "validation");
         return false;
     }
     return true;
 }
開發者ID:ivoba,項目名稱:silverstripe-framework,代碼行數:14,代碼來源:TextField.php

示例4: validate

 /**
  * Validate this field
  *
  * @param Validator $validator
  * @return bool
  */
 public function validate($validator)
 {
     if (!$this->value) {
         return true;
     }
     if ($this->isNumeric()) {
         return true;
     }
     $validator->validationError($this->name, _t('NumericField.VALIDATION', "'{value}' is not a number, only numbers can be accepted for this field", array('value' => $this->value)), "validation");
     return false;
 }
開發者ID:nicocin,項目名稱:silverstripe-framework,代碼行數:17,代碼來源:NumericField.php

示例5: validate

 /**
  * Validate this field
  *
  * @param Validator $validator
  * @return bool
  */
 public function validate($validator)
 {
     if (self::getValidateOnSubmit()) {
         return true;
     } else {
         if (strtoupper($this->value) === SimpleCaptchaController::getCaptchaID()) {
             return true;
         }
         $validator->validationError($this->name, sprintf("%s is wrong, Correct captcha is required", $this->value), "validation");
         return false;
     }
 }
開發者ID:helpfulrobot,項目名稱:chitosystems-silverstripe-simple-captcha-field,代碼行數:18,代碼來源:SimpleCaptchaField.php

示例6: validate

 /**
  * Validates for RFC 2822 compliant email addresses.
  *
  * @see http://www.regular-expressions.info/email.html
  * @see http://www.ietf.org/rfc/rfc2822.txt
  *
  * @param Validator $validator
  *
  * @return string
  */
 public function validate($validator)
 {
     $this->value = trim($this->value);
     $pattern = '^[a-z0-9!#$%&\'*+/=?^_`{|}~-]+(?:\\.[a-z0-9!#$%&\'*+/=?^_`{|}~-]+)*@(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?$';
     // Escape delimiter characters.
     $safePattern = str_replace('/', '\\/', $pattern);
     if ($this->value && !preg_match('/' . $safePattern . '/i', $this->value)) {
         $validator->validationError($this->name, _t('EmailField.VALIDATION', 'Please enter an email address'), 'validation');
         return false;
     }
     return true;
 }
開發者ID:SpiritLevel,項目名稱:silverstripe-framework,代碼行數:22,代碼來源:EmailField.php

示例7: validateValue

 /**
  * Checks if a certain field value is valid.
  *
  * @param  string $value
  * @param  Validator $validator
  */
 public function validateValue($value, $validator)
 {
     if (!$this->Required) {
         return;
     }
     if (is_array($value)) {
         return;
     }
     //  eg. checkbox set values
     if (!strlen($value)) {
         $validator->validationError('MetadataRaw', sprintf('The metadata field "%s" on the "%s" schema is required', $this->Title, $this->Schema()->Title), 'validation');
     }
 }
開發者ID:phill-m,項目名稱:silverstripe-metadata,代碼行數:19,代碼來源:MetadataField.php

示例8: validate

 /**
  * Validates for RFC 2822 compliant email adresses.
  * 
  * @see http://www.regular-expressions.info/email.html
  * @see http://www.ietf.org/rfc/rfc2822.txt
  * 
  * @param Validator $validator
  * @return String
  */
 function validate($validator)
 {
     $this->value = trim($this->value);
     $pcrePattern = '^[a-z0-9!#$%&\'*+/=?^_`{|}~-]+(?:\\.[a-z0-9!#$%&\'*+/=?^_`{|}~-]+)*@(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?$';
     // PHP uses forward slash (/) to delimit start/end of pattern, so it must be escaped
     $pregSafePattern = str_replace('/', '\\/', $pcrePattern);
     if ($this->value && !preg_match('/' . $pregSafePattern . '/i', $this->value)) {
         $validator->validationError($this->name, _t('EmailField.VALIDATION', "Please enter an email address."), "validation");
         return false;
     } else {
         return true;
     }
 }
開發者ID:SustainableCoastlines,項目名稱:loveyourwater,代碼行數:22,代碼來源:EmailField.php

示例9: validate

 /**
  * Validate this field
  *
  * @param Validator $validator
  * @return bool
  */
 public function validate($validator)
 {
     $value = isset($_POST[$this->name . '_custom']) ? $_POST[$this->name . '_custom'] : null;
     if (!$value) {
         return true;
     }
     // no custom value, don't validate
     // Check that the current date with the date format is valid or not
     require_once 'Zend/Date.php';
     $date = Zend_Date::now()->toString($value);
     $valid = Zend_Date::isDate($date, $value);
     if ($valid) {
         return true;
     } else {
         if ($validator) {
             $validator->validationError($this->name, _t('MemberDatetimeOptionsetField.DATEFORMATBAD', "Date format is invalid"), "validation", false);
         }
         return false;
     }
 }
開發者ID:ivoba,項目名稱:silverstripe-framework,代碼行數:26,代碼來源:MemberDatetimeOptionsetField.php

示例10: validate

 /**
  * Validate this field
  *
  * @param Validator $validator
  * @return bool
  */
 public function validate($validator)
 {
     $name = $this->name;
     // if field isn't visible, don't validate
     if (!$this->isSaveable()) {
         return true;
     }
     $this->passwordField->setValue($this->value);
     $this->confirmPasswordfield->setValue($this->confirmValue);
     $value = $this->passwordField->Value();
     // both password-fields should be the same
     if ($value != $this->confirmPasswordfield->Value()) {
         $validator->validationError($name, _t('Form.VALIDATIONPASSWORDSDONTMATCH', "Passwords don't match"), "validation");
         return false;
     }
     if (!$this->canBeEmpty) {
         // both password-fields shouldn't be empty
         if (!$value || !$this->confirmPasswordfield->Value()) {
             $validator->validationError($name, _t('Form.VALIDATIONPASSWORDSNOTEMPTY', "Passwords can't be empty"), "validation");
             return false;
         }
     }
     // lengths
     if ($this->minLength || $this->maxLength) {
         $errorMsg = null;
         $limit = null;
         if ($this->minLength && $this->maxLength) {
             $limit = "{{$this->minLength},{$this->maxLength}}";
             $errorMsg = _t('ConfirmedPasswordField.BETWEEN', 'Passwords must be {min} to {max} characters long.', array('min' => $this->minLength, 'max' => $this->maxLength));
         } elseif ($this->minLength) {
             $limit = "{{$this->minLength}}.*";
             $errorMsg = _t('ConfirmedPasswordField.ATLEAST', 'Passwords must be at least {min} characters long.', array('min' => $this->minLength));
         } elseif ($this->maxLength) {
             $limit = "{0,{$this->maxLength}}";
             $errorMsg = _t('ConfirmedPasswordField.MAXIMUM', 'Passwords must be at most {max} characters long.', array('max' => $this->maxLength));
         }
         $limitRegex = '/^.' . $limit . '$/';
         if (!empty($value) && !preg_match($limitRegex, $value)) {
             $validator->validationError($name, $errorMsg, "validation");
         }
     }
     if ($this->requireStrongPassword) {
         if (!preg_match('/^(([a-zA-Z]+\\d+)|(\\d+[a-zA-Z]+))[a-zA-Z0-9]*$/', $value)) {
             $validator->validationError($name, _t('Form.VALIDATIONSTRONGPASSWORD', "Passwords must have at least one digit and one alphanumeric character"), "validation");
             return false;
         }
     }
     // Check if current password is valid
     if (!empty($value) && $this->getRequireExistingPassword()) {
         if (!$this->currentPasswordValue) {
             $validator->validationError($name, _t('ConfirmedPasswordField.CURRENT_PASSWORD_MISSING', "You must enter your current password."), "validation");
             return false;
         }
         // Check this password is valid for the current user
         $member = Member::currentUser();
         if (!$member) {
             $validator->validationError($name, _t('ConfirmedPasswordField.LOGGED_IN_ERROR', "You must be logged in to change your password."), "validation");
             return false;
         }
         // With a valid user and password, check the password is correct
         $checkResult = $member->checkPassword($this->currentPasswordValue);
         if (!$checkResult->valid()) {
             $validator->validationError($name, _t('ConfirmedPasswordField.CURRENT_PASSWORD_ERROR', "The current password you have entered is not correct."), "validation");
             return false;
         }
     }
     return true;
 }
開發者ID:jacobbuck,項目名稱:silverstripe-framework,代碼行數:74,代碼來源:ConfirmedPasswordField.php

示例11: validationError

 /**
  * @param string $fieldName
  * @param string $message
  * @param string $messageType
  */
 public function validationError($fieldName, $message, $messageType = '')
 {
     // Just make any error use the form message
     $this->form->sessionMessage($message, $messageType);
     parent::validationError($fieldName, $message, $messageType);
 }
開發者ID:helpfulrobot,項目名稱:silverstripe-deploynaut,代碼行數:11,代碼來源:DeployForm.php

示例12: validateDomain

 /**
  * Validate the value of this EmailField agianst our list of allowed and disallowed domains
  * @param  Validator $validator
  * @return bool
  */
 protected function validateDomain(Validator $validator)
 {
     // If we can't get a domain from the current value, just quite validating the domain.
     $domain = $this->getDomain();
     if (!$domain) {
         return true;
     }
     // Validate against the allowed domain list
     if ($this->allowedDomains && !$this->valueInList($domain, $this->allowedDomains)) {
         // Build the message
         $message = _t('DomainSpecificEmailField.ALLOWEDDOMAIN', 'The email address is not from an allowed domain.');
         if ($this->showListOnError) {
             $message .= ' ' . _t('DomainSpecificEmailField.ALLOWEDDOMAINLLIST', 'The following domains are allowed: ') . implode(', ', $this->allowedDomains);
         }
         // Record the error
         $validator->validationError($this->getName(), $message);
         return false;
     }
     // Validate against the disallowed domain list
     if ($this->disallowedDomains && $this->valueInList($domain, $this->disallowedDomains)) {
         // Build messgae
         $message = _t('DomainSpecificEmailField.DISALLOWEDDOMAIN', 'The email address is from a disallowed domain.');
         if ($this->showListOnError) {
             $message .= ' ' . _t('DomainSpecificEmailField.DISALLOWEDDOMAINLLIST', 'The following domains are disallowed: ') . implode(', ', $this->disallowedDomains);
         }
         // Record error
         $validator->validationError($this->getName(), $message);
         return false;
     }
     // Made it all the way without incident. Domain is valid.
     return true;
 }
開發者ID:firebrandhq,項目名稱:domain-specific-memberprofiles,代碼行數:37,代碼來源:DomainSpecificEmailField.php

示例13: validate

 /**
  * Validate this field
  *
  * @param Validator $validator
  * @return bool
  */
 public function validate($validator)
 {
     $valid = false;
     $source = $this->getSourceAsArray();
     $disabled = $this->getDisabledItems();
     if ($this->value) {
         foreach ($source as $value => $title) {
             if (is_array($title) && array_key_exists($this->value, $title)) {
                 // Check that the set value is not in the list of disabled items
                 if (!isset($disabled[$value]) || !in_array($this->value, $disabled[$value])) {
                     $valid = true;
                 }
                 // Check that the value matches and is not disabled
             } elseif ($this->value == $value && !in_array($this->value, $disabled)) {
                 $valid = true;
             }
         }
     } elseif ($this->getHasEmptyDefault()) {
         $valid = true;
     }
     if (!$valid) {
         $validator->validationError($this->name, _t('DropdownField.SOURCE_VALIDATION', "Please select a value within the list provided. {value} is not a valid option", array('value' => $this->value)), "validation");
         return false;
     }
     return true;
 }
開發者ID:ivoba,項目名稱:silverstripe-framework,代碼行數:32,代碼來源:GroupedDropdownField.php

示例14: validate

 /**
  * Validate the captcha information
  *
  * @param Validator $validator
  *
  * @return boolean
  */
 public function validate($validator)
 {
     // Bypass spam detection for eligible users
     if ($this->exemptUser()) {
         $this->clearMollomSession();
         return true;
     }
     $session_id = Session::get("mollom_session_id");
     $mapped = $this->getSpamMappedData();
     $data = array();
     // prepare submission
     foreach (array('authorName', 'authorUrl', 'authorMail', 'authorIp', 'authorId') as $k) {
         if (isset($mapped[$k])) {
             $data[$k] = $mapped[$k];
         }
     }
     if ($session_id) {
         // session ID exists so has been checked by captcha
         $data['id'] = $session_id;
         $data['solution'] = $this->Value();
         $result = $this->getMollom()->checkCaptcha($data);
         if (is_array($result)) {
             if ($result['solved']) {
                 $this->clearMollomSession();
                 return true;
             } else {
                 $this->requestMollom();
                 $validator->validationError($this->name, _t('MollomCaptchaField.CAPTCHAREQUESTED', "Please answer the captcha question", "Mollom Captcha provides words in an image, and expects a user to type them in a textfield"), "warning");
                 return false;
             }
         }
     } else {
         $contentMap = array('id' => 'id', 'title' => 'postTitle', 'body' => 'postBody');
         foreach ($contentMap as $k => $v) {
             if (isset($mapped[$k])) {
                 $data[$v] = $mapped[$k];
             }
         }
         $result = $this->getMollom()->checkContent($data);
         // Mollom can do much more useful things.
         // @todo handle profanityScore, qualityScore, sentimentScore, reason
         if (is_array($result)) {
             switch ($result['spamClassification']) {
                 case 'ham':
                     $this->clearMollomSession();
                     return true;
                 case 'unsure':
                     $this->requestMollom();
                     // we're unsure so request the captcha.
                     $validator->validationError($this->name, _t('MollomCaptchaField.CAPTCHAREQUESTED', "Please answer the captcha question", "Mollom Captcha provides words in an image, and expects a user to type them in a textfield"), "warning");
                     return false;
                 case 'spam':
                     $this->clearMollomSession();
                     $this->requestMollom();
                     $validator->validationError($this->name, _t('MollomCaptchaField.SPAM', "Your submission has been rejected because it was treated as spam.", "Mollom Captcha provides words in an image, and expects a user to type them in a textfield"), "error");
                     return false;
                     break;
             }
         }
     }
     return true;
 }
開發者ID:helpfulrobot,項目名稱:silverstripe-mollom,代碼行數:69,代碼來源:MollomField.php

示例15: validate

 /**
  * Validate by submitting to external service
  *
  * @todo implement socket timeout handling (or switch to curl?)
  * @param Validator $validator
  * @return boolean
  */
 public function validate($validator)
 {
     // don't bother querying the recaptcha-service if fields were empty
     if (!isset($_REQUEST['g-recaptcha-response']) || empty($_REQUEST['g-recaptcha-response'])) {
         $validator->validationError($this->name, _t('RecaptchaField.EMPTY', "Please answer the captcha question", "Recaptcha (https://www.google.com/recaptcha) protects this website " . "from spam and abuse."), "validation", false);
         return false;
     }
     $response = $this->recaptchaHTTPPost($_REQUEST['g-recaptcha-response']);
     if (!$response) {
         $validator->validationError($this->name, _t('RecaptchaField.NORESPONSE', "The recaptcha service gave no response. Please try again later.", "Recaptcha (https://www.google.com/recaptcha) protects this website " . "from spam and abuse."), "validation", false);
         return false;
     }
     // get the payload of the response and decode it
     $response = json_decode($response, true);
     if ($response['success'] != 'true') {
         // Count some errors as "user level", meaning they raise a validation error rather than a system error
         $userLevelErrors = array('missing-input-response', 'invalid-input-response');
         if (count(array_intersect($response['error-codes'], $userLevelErrors)) === 0) {
             $error = implode(', ', $response['error-codes']);
             user_error("RecatpchaField::validate(): Recaptcha-service error: '{$error}'", E_USER_ERROR);
             return false;
         } else {
             // Internal error-string returned by recaptcha, e.g. "incorrect-captcha-sol".
             // Used to generate the new iframe-url/js-url after form-refresh.
             Session::set("FormField.{$this->form->FormName()}.{$this->getName()}.error", trim($error));
             $validator->validationError($this->name, _t('RecaptchaField.VALIDSOLUTION', "Your answer didn't match the captcha words, please try again", "Recaptcha (https://www.google.com/recaptcha) protects this website " . "from spam and abuse."), "validation", false);
             return false;
         }
     }
     return true;
 }
開發者ID:suhongyang,項目名稱:silverstripe-recaptcha,代碼行數:38,代碼來源:RecaptchaField.php


注:本文中的Validator::validationError方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。