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


PHP Helper::getParameterName方法代碼示例

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


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

示例1: testParameterNameMethod

 public function testParameterNameMethod()
 {
     $value = Helper::getParameterName(':my_param_name');
     $this->assertEquals('my_param_name', $value);
     $value = Helper::getParameterName(':my_param_name?');
     $this->assertEquals('my_param_name', $value);
     $value = Helper::getParameterName(':my_param_name?default value');
     $this->assertEquals('my_param_name', $value);
     $value = Helper::getParameterName(':my_param_name|^[a-z]+[0-9]?$');
     $this->assertEquals('my_param_name', $value);
     $value = Helper::getParameterName(':my_param_name|^[a-z]+[0-9]?$');
     $this->assertEquals('my_param_name', $value);
     $value = Helper::getParameterName(':my_param_name?default value|^[a-z]+[0-9]?$');
     $this->assertEquals('my_param_name', $value);
 }
開發者ID:brenodouglas,項目名稱:library,代碼行數:15,代碼來源:RouterHelperTest.php

示例2: resolveUrl

 /**
  * Checks whether a given URL matches a given pattern.
  * @param string $url The URL to check.
  * @param array $parameters A reference to a PHP array variable to return the parameter list fetched from URL.
  * @return boolean Returns true if the URL matches the pattern. Otherwise returns false.
  */
 public function resolveUrl($url, &$parameters)
 {
     $parameters = [];
     $patternSegments = $this->segments;
     $patternSegmentNum = count($patternSegments);
     $urlSegments = Helper::segmentizeUrl($url);
     /*
      * Only one wildcard can be used, if found, pull out the excess segments
      */
     if ($this->wildSegmentCount === 1) {
         $wildSegments = $this->captureWildcardSegments($urlSegments);
     }
     /*
      * If the number of URL segments is more than the number of pattern segments - return false
      */
     if (count($urlSegments) > count($patternSegments)) {
         return false;
     }
     /*
      * Compare pattern and URL segments
      */
     foreach ($patternSegments as $index => $patternSegment) {
         $patternSegmentLower = mb_strtolower($patternSegment);
         if (strpos($patternSegment, ':') !== 0) {
             /*
              * Static segment
              */
             if (!array_key_exists($index, $urlSegments) || $patternSegmentLower != mb_strtolower($urlSegments[$index])) {
                 return false;
             }
         } else {
             /*
              * Dynamic segment. Initialize the parameter
              */
             $paramName = Helper::getParameterName($patternSegment);
             $parameters[$paramName] = false;
             /*
              * Determine whether it is optional
              */
             $optional = Helper::segmentIsOptional($patternSegment);
             /*
              * Check if the optional segment has no required segments following it
              */
             if ($optional && $index < $patternSegmentNum - 1) {
                 for ($i = $index + 1; $i < $patternSegmentNum; $i++) {
                     if (!Helper::segmentIsOptional($patternSegments[$i])) {
                         $optional = false;
                         break;
                     }
                 }
             }
             /*
              * If the segment is optional and there is no corresponding value in the URL, assign the default value (if provided)
              * and skip to the next segment.
              */
             $urlSegmentExists = array_key_exists($index, $urlSegments);
             if ($optional && !$urlSegmentExists) {
                 $parameters[$paramName] = Helper::getSegmentDefaultValue($patternSegment);
                 continue;
             }
             /*
              * If the segment is not optional and there is no corresponding value in the URL, return false
              */
             if (!$optional && !$urlSegmentExists) {
                 return false;
             }
             /*
              * Validate the value with the regular expression
              */
             $regexp = Helper::getSegmentRegExp($patternSegment);
             if ($regexp) {
                 try {
                     if (!preg_match($regexp, $urlSegments[$index])) {
                         return false;
                     }
                 } catch (\Exception $ex) {
                 }
             }
             /*
              * Set the parameter value
              */
             $parameters[$paramName] = $urlSegments[$index];
             /*
              * Determine if wildcard and add stored paramters as a suffix
              */
             if (Helper::segmentIsWildcard($patternSegment) && count($wildSegments)) {
                 $parameters[$paramName] .= Helper::rebuildUrl($wildSegments);
             }
         }
     }
     return true;
 }
開發者ID:betes-curieuses-design,項目名稱:ElieJosiePhotographie,代碼行數:98,代碼來源:Rule.php


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