>백엔드 개발 >PHP 튜토리얼 >Zend Framework 유효성 검사기 Zend_Validate의 사용 분석

Zend Framework 유효성 검사기 Zend_Validate의 사용 분석

不言
不言원래의
2018-06-09 14:51:072423검색

본 글은 주로 Zend Framework 검증인 Zend_Validate의 사용법을 소개하고, 검증인 Zend_Validate의 기능, 사용 기술, 관련 주의사항을 예시 형태로 분석해 놓았으니 필요한 친구들이 참고할 수 있습니다.

본 글의 예시는 Zend Framework 검증 장치 Zend_사용을 확인합니다. 참조용으로 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.

소개:

는 입력 콘텐츠를 확인하고 콘텐츠가 성공적으로 확인되었는지 여부를 나타내는 부울 결과를 생성하는 메커니즘입니다.

isValid() 메서드가 False를 반환하는 경우 하위 클래스의 getMessage() 메서드는 확인 실패 이유를 설명하는 메시지 배열을 반환합니다.

메시지와 오류 내용을 올바르게 반환하려면 isValid() 메서드를 호출할 때마다 이전 isValid() 메서드 호출로 인해 발생한 메시지와 오류를 지워야 합니다.

사례:

<?php
require_once &#39;Zend/Validate/EmailAddress.php&#39;;
function c_email($email)
{
  $validator = new Zend_Validate_EmailAddress();
  if($validator->isValid($email)){
    echo "输入的E-mail地址:";
    echo $email."有效!<p>";
  }else{
    echo "输入的E-mail地址:";
    echo $email."无效!";
    echo "失败消息为:<p>";
    foreach($validator->getMessages() as $message){
      echo $message."<p>";
    }
    foreach($validator->getErrors() as $error){
      echo $error."<p>";
    }
  }
}
$e_m1 = "abc@123.com";
$e_m2 = "abc#123.com";
c_email($e_m1);
c_email($e_m2);

결과:

입력한 이메일 주소: abc@123.com이 유효합니다!
입력한 이메일 주소: abc#123.com이 잘못되었습니다! 실패 메시지는 다음과 같습니다.
'abc#123.com'은 기본 형식 local-part@hostname
emailAddressInvalidFormat

설명:

클래스를 소개한 후 확인 기능을 정의합니다. 함수는 에서 클래스를 인스턴스화합니다. isValid() 메서드를 사용하여 다양한 하위 클래스 유효성 검사기가 다양한 내용을 확인합니다.
getMessages() 메서드와 getErrors() 메서드를 동시에 사용하세요.

소스 코드 감상:

public function isValid($value)
{
    if (!is_string($value)) {
      $this->_error(self::INVALID);
      return false;
    }
    $matches = array();
    $length = true;
    $this->_setValue($value);
    // Split email address up and disallow &#39;..&#39;
    if ((strpos($value, &#39;..&#39;) !== false) or
      (!preg_match(&#39;/^(.+)@([^@]+)$/&#39;, $value, $matches))) {
      $this->_error(self::INVALID_FORMAT);
      return false;
    }
    $this->_localPart = $matches[1];
    $this->_hostname = $matches[2];
    if ((strlen($this->_localPart) > 64) || (strlen($this->_hostname) > 255)) {
      $length = false;
      $this->_error(self::LENGTH_EXCEEDED);
    }
    // Match hostname part
    if ($this->_options[&#39;domain&#39;]) {
      $hostname = $this->_validateHostnamePart();
    }
    $local = $this->_validateLocalPart();
    // If both parts valid, return true
    if ($local && $length) {
      if (($this->_options[&#39;domain&#39;] && $hostname) || !$this->_options[&#39;domain&#39;]) {
        return true;
      }
    }
    return false;
}

분석:

본 검증 기능 내용으로, 문자열인지, 이메일 규칙에 맞는지, 검증을 위한 여러 상황으로 나누어져 있습니다. 길이가 일치하는지 여부는 모두 일치하는 경우에만 반환됩니다.

위 내용은 이 글의 전체 내용입니다. 모든 분들의 학습에 도움이 되었으면 좋겠습니다. 더 많은 관련 내용은 PHP 중국어 홈페이지를 주목해주세요!

관련 추천:

Zend Framework

내 Zend_View 구성 요소 사용 분석

위 내용은 Zend Framework 유효성 검사기 Zend_Validate의 사용 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.