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


PHP PhoneNumber::setExtension方法代碼示例

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


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

示例1: parseHelper

 /**
  * Parses a string and fills up the phoneNumber. This method is the same as the public
  * parse() method, with the exception that it allows the default region to be null, for use by
  * isNumberMatch(). checkRegion should be set to false if it is permitted for the default region
  * to be null or unknown ("ZZ").
  * @param string $numberToParse
  * @param string $defaultRegion
  * @param bool $keepRawInput
  * @param bool $checkRegion
  * @param PhoneNumber $phoneNumber
  * @throws NumberParseException
  */
 private function parseHelper($numberToParse, $defaultRegion, $keepRawInput, $checkRegion, PhoneNumber $phoneNumber)
 {
     if ($numberToParse === null) {
         throw new NumberParseException(NumberParseException::NOT_A_NUMBER, "The phone number supplied was null.");
     }
     $numberToParse = trim($numberToParse);
     if (mb_strlen($numberToParse) > self::MAX_INPUT_STRING_LENGTH) {
         throw new NumberParseException(NumberParseException::TOO_LONG, "The string supplied was too long to parse.");
     }
     $nationalNumber = '';
     $this->buildNationalNumberForParsing($numberToParse, $nationalNumber);
     if (!$this->isViablePhoneNumber($nationalNumber)) {
         throw new NumberParseException(NumberParseException::NOT_A_NUMBER, "The string supplied did not seem to be a phone number.");
     }
     // Check the region supplied is valid, or that the extracted number starts with some sort of +
     // sign so the number's region can be determined.
     if ($checkRegion && !$this->checkRegionForParsing($nationalNumber, $defaultRegion)) {
         throw new NumberParseException(NumberParseException::INVALID_COUNTRY_CODE, "Missing or invalid default region.");
     }
     if ($keepRawInput) {
         $phoneNumber->setRawInput($numberToParse);
     }
     // Attempt to parse extension first, since it doesn't require region-specific data and we want
     // to have the non-normalised number here.
     $extension = $this->maybeStripExtension($nationalNumber);
     if (mb_strlen($extension) > 0) {
         $phoneNumber->setExtension($extension);
     }
     $regionMetadata = $this->getMetadataForRegion($defaultRegion);
     // Check to see if the number is given in international format so we know whether this number is
     // from the default region or not.
     $normalizedNationalNumber = "";
     try {
         // TODO: This method should really just take in the string buffer that has already
         // been created, and just remove the prefix, rather than taking in a string and then
         // outputting a string buffer.
         $countryCode = $this->maybeExtractCountryCode($nationalNumber, $regionMetadata, $normalizedNationalNumber, $keepRawInput, $phoneNumber);
     } catch (NumberParseException $e) {
         $matcher = new Matcher(self::$PLUS_CHARS_PATTERN, $nationalNumber);
         if ($e->getErrorType() == NumberParseException::INVALID_COUNTRY_CODE && $matcher->lookingAt()) {
             // Strip the plus-char, and try again.
             $countryCode = $this->maybeExtractCountryCode(substr($nationalNumber, $matcher->end()), $regionMetadata, $normalizedNationalNumber, $keepRawInput, $phoneNumber);
             if ($countryCode == 0) {
                 throw new NumberParseException(NumberParseException::INVALID_COUNTRY_CODE, "Could not interpret numbers after plus-sign.");
             }
         } else {
             throw new NumberParseException($e->getErrorType(), $e->getMessage(), $e);
         }
     }
     if ($countryCode !== 0) {
         $phoneNumberRegion = $this->getRegionCodeForCountryCode($countryCode);
         if ($phoneNumberRegion != $defaultRegion) {
             // Metadata cannot be null because the country calling code is valid.
             $regionMetadata = $this->getMetadataForRegionOrCallingCode($countryCode, $phoneNumberRegion);
         }
     } else {
         // If no extracted country calling code, use the region supplied instead. The national number
         // is just the normalized version of the number we were given to parse.
         $normalizedNationalNumber .= $this->normalize($nationalNumber);
         if ($defaultRegion !== null) {
             $countryCode = $regionMetadata->getCountryCode();
             $phoneNumber->setCountryCode($countryCode);
         } else {
             if ($keepRawInput) {
                 $phoneNumber->clearCountryCodeSource();
             }
         }
     }
     if (mb_strlen($normalizedNationalNumber) < self::MIN_LENGTH_FOR_NSN) {
         throw new NumberParseException(NumberParseException::TOO_SHORT_NSN, "The string supplied is too short to be a phone number.");
     }
     if ($regionMetadata !== null) {
         $carrierCode = "";
         $potentialNationalNumber = $normalizedNationalNumber;
         $this->maybeStripNationalPrefixAndCarrierCode($potentialNationalNumber, $regionMetadata, $carrierCode);
         // We require that the NSN remaining after stripping the national prefix and carrier code be
         // of a possible length for the region. Otherwise, we don't do the stripping, since the
         // original number could be a valid short number.
         if (!$this->isShorterThanPossibleNormalNumber($regionMetadata, $potentialNationalNumber)) {
             $normalizedNationalNumber = $potentialNationalNumber;
             if ($keepRawInput) {
                 $phoneNumber->setPreferredDomesticCarrierCode($carrierCode);
             }
         }
     }
     $lengthOfNationalNumber = mb_strlen($normalizedNationalNumber);
     if ($lengthOfNationalNumber < self::MIN_LENGTH_FOR_NSN) {
         throw new NumberParseException(NumberParseException::TOO_SHORT_NSN, "The string supplied is too short to be a phone number.");
//.........這裏部分代碼省略.........
開發者ID:kasirye,項目名稱:faveo-helpdesk,代碼行數:101,代碼來源:PhoneNumberUtil.php

示例2: parseHelper

 /**
  * Parses a string and fills up the phoneNumber. This method is the same as the public
  * parse() method, with the exception that it allows the default region to be null, for use by
  * isNumberMatch(). checkRegion should be set to false if it is permitted for the default region
  * to be null or unknown ("ZZ").
  * @param $numberToParse
  * @param string $defaultRegion
  * @param $keepRawInput
  * @param $checkRegion
  * @param PhoneNumber $phoneNumber
  * @throws NumberParseException
  */
 private function parseHelper($numberToParse, $defaultRegion, $keepRawInput, $checkRegion, PhoneNumber $phoneNumber)
 {
     if ($numberToParse == null) {
         throw new NumberParseException(NumberParseException::NOT_A_NUMBER, "The phone number supplied was null.");
     }
     // Extract a possible number from the string passed in (this strips leading characters that
     // could not be the start of a phone number.)
     $number = $this->extractPossibleNumber($numberToParse);
     if (!$this->isViablePhoneNumber($number)) {
         throw new NumberParseException(NumberParseException::NOT_A_NUMBER, "The string supplied did not seem to be a phone number.");
     }
     // Check the region supplied is valid, or that the extracted number starts with some sort of +
     // sign so the number's region can be determined.
     if ($checkRegion && !$this->checkRegionForParsing($number, $defaultRegion)) {
         throw new NumberParseException(NumberParseException::INVALID_COUNTRY_CODE, "Missing or invalid default region.");
     }
     if ($keepRawInput) {
         $phoneNumber->setRawInput($numberToParse);
     }
     $nationalNumber = $number;
     // Attempt to parse extension first, since it doesn't require region-specific data and we want
     // to have the non-normalised number here.
     $extension = $this->maybeStripExtension($nationalNumber);
     if (strlen($extension) > 0) {
         $phoneNumber->setExtension($extension);
     }
     $regionMetadata = $this->getMetadataForRegion($defaultRegion);
     // Check to see if the number is given in international format so we know whether this number is
     // from the default region or not.
     $normalizedNationalNumber = "";
     $countryCode = 0;
     try {
         // TODO: This method should really just take in the string buffer that has already
         // been created, and just remove the prefix, rather than taking in a string and then
         // outputting a string buffer.
         $countryCode = $this->maybeExtractCountryCode($nationalNumber, $regionMetadata, $normalizedNationalNumber, $keepRawInput, $phoneNumber);
     } catch (NumberParseException $e) {
         $matcher = new Matcher(self::$PLUS_CHARS_PATTERN, $nationalNumber);
         if ($e->getErrorType() == NumberParseException::INVALID_COUNTRY_CODE && $matcher->lookingAt()) {
             // Strip the plus-char, and try again.
             $countryCode = $this->maybeExtractCountryCode(substr($nationalNumber, $matcher->end()), $regionMetadata, $normalizedNationalNumber, $keepRawInput, $phoneNumber);
             if ($countryCode == 0) {
                 throw new NumberParseException(NumberParseException::INVALID_COUNTRY_CODE, "Could not interpret numbers after plus-sign.");
             }
         } else {
             throw new NumberParseException($e->getErrorType(), $e->getMessage());
         }
     }
     if ($countryCode !== 0) {
         $phoneNumberRegion = $this->getRegionCodeForCountryCode($countryCode);
         if ($phoneNumberRegion != $defaultRegion) {
             $regionMetadata = $this->getMetadataForRegionOrCallingCode($countryCode, $phoneNumberRegion);
         }
     } else {
         // If no extracted country calling code, use the region supplied instead. The national number
         // is just the normalized version of the number we were given to parse.
         $normalizedNationalNumber .= $this->normalize($nationalNumber);
         if ($defaultRegion != null) {
             $countryCode = $regionMetadata->getCountryCode();
             $phoneNumber->setCountryCode($countryCode);
         } else {
             if ($keepRawInput) {
                 $phoneNumber->clearCountryCodeSource();
             }
         }
     }
     if (strlen($normalizedNationalNumber) < self::MIN_LENGTH_FOR_NSN) {
         throw new NumberParseException(NumberParseException::TOO_SHORT_NSN, "The string supplied is too short to be a phone number.");
     }
     if ($regionMetadata != null) {
         $carrierCode = "";
         $this->maybeStripNationalPrefixAndCarrierCode($normalizedNationalNumber, $regionMetadata, $carrierCode);
         if ($keepRawInput) {
             $phoneNumber->setPreferredDomesticCarrierCode($carrierCode);
         }
     }
     $lengthOfNationalNumber = strlen($normalizedNationalNumber);
     if ($lengthOfNationalNumber < self::MIN_LENGTH_FOR_NSN) {
         throw new NumberParseException(NumberParseException::TOO_SHORT_NSN, "The string supplied is too short to be a phone number.");
     }
     if ($lengthOfNationalNumber > self::MAX_LENGTH_FOR_NSN) {
         throw new NumberParseException(NumberParseException::TOO_LONG, "The string supplied is too long to be a phone number.");
     }
     if ($normalizedNationalNumber[0] == '0') {
         $phoneNumber->setItalianLeadingZero(true);
     }
     $phoneNumber->setNationalNumber((double) $normalizedNationalNumber);
 }
開發者ID:verheesj,項目名稱:libphonenumber,代碼行數:100,代碼來源:PhoneNumberUtil.php


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