中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Zend Framework框架路由機制的示例分析

發布時間:2021-09-02 09:29:59 來源:億速云 閱讀:140 作者:小新 欄目:開發技術

小編給大家分享一下Zend Framework框架路由機制的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

具體如下:

在框架中,有關路由的調用關系為:

1、apache的mod_rewrite模塊把請求路由到框架的啟動腳本,一般是index.php;

2、前端控制器Zend_Controller_Front通過dispatch函數進行請求分發;

3、路由器Zend_Controller_Router_Rewrite通過route函數處理路由,對路由器中已有的路由規則,按照加入順序的逆序(類似于棧,后進先出)對每個route調用match函數,以檢查請求是否和當前路由規則匹配,如果匹配的話把路由器的當前路由這個變量($_currentRoute)設置為匹配的路由,并把route解析出來的參數傳給Zend_Controller_Request_Http對象,到這里完成路由設置。

如果沒有發現路由,框架會使用Index控制器的index這個action。

對Zend_Controller_Router_Route中的函數代碼分析:

1、構造函數

public function __construct($route, $defaults = array(), $reqs = array())
{
  $route = trim($route, $this->_urlDelimiter); //去掉規則首尾的url分隔符(默認是/)
  $this->_defaults = (array) $defaults; //默認值數組,以變量名為鍵
  $this->_requirements = (array) $reqs; //變量需要滿足的正則表達式,以變量名為鍵
  if ($route != '') {
   foreach (explode($this->_urlDelimiter, $route) as $pos => $part) {
    //把規則切分為一個數組
    if (substr($part, 0, 1) == $this->_urlVariable) {//如果是一個變量的定義
     $name = substr($part, 1); //獲取變量名
     //如果該變量定義了對應的正則表達式,則獲取該表達式,否則置為null
     $regex = (isset($reqs[$name]) ? $reqs[$name] : $this->_defaultRegex);
     //_parts數組包含了規則的各個部分,如果是變量的話,數組中有name元素
     $this->_parts[$pos] = array('name' => $name, 'regex' => $regex);
     //_vars包含了該規則中的所有變量的名字
     $this->_vars[] = $name;
    } else { //普通字符串
     $this->_parts[$pos] = array('regex' => $part);
     if ($part != '*') {
      $this->_staticCount++; //該規則的普通字符串的個數
     }
    }
   }
  }
}

2、匹配算法

public function match($path)
{
  $pathStaticCount = 0;
  $defaults = $this->_defaults; //默認值數組,數組元素的鍵值是變量名
   //默認值數組的一個拷貝,不過變量的值全部換成布爾值,其實這個值并沒有實際用處,下面程序僅僅
  //是通過判斷鍵值是否存在而確定是否包含一個變量,可能這么做是為了節省空間,不過要是這樣的話
  //不如直接使用 $this->_defaults了?
  if (count($defaults)) {
   $unique = array_combine(array_keys($defaults), array_fill(0, count($defaults), true));
  } else {
   $unique = array();
  }
  $path = trim($path, $this->_urlDelimiter); //傳入的path是已經去掉baseUrl的,這里確保去掉首尾的分隔符
  if ($path != '') {
   $path = explode($this->_urlDelimiter, $path);
   foreach ($path as $pos => $pathPart) {
    if (!isset($this->_parts[$pos])) {
     //把path根據url分隔符分割為數組后,把每一部分和規則的對應部分比較,如果path中存在,
     //而規則中不存在對應部分,那么該規則肯定不匹配,這里要注意$pos,是通過它把規則
     //和path的對應部分對應起來。
     return false;
    }
    if ($this->_parts[$pos]['regex'] == '*') {
      //如果規則的當前部分是通配符*,則把path的剩余部分解釋為url傳遞過來的變量,他們按照
     //“變量名/變量值”這樣的形式成對出現
     $parts = array_slice($path, $pos); //獲取path的剩余部分
     $this->_getWildcardData($parts, $unique);
     break;
    }
    $part = $this->_parts[$pos];
    $name = isset($part['name']) ? $part['name'] : null;
    $pathPart = urldecode($pathPart);//對傳過來的值進行解碼
    if ($name === null) {//普通字符串,和規則的對應部分比較是否相等即可
     if ($part['regex'] != $pathPart) {
      return false;
     }
    } elseif ($part['regex'] === null) {
      //如果是變量,但是沒有需要滿足的正則表達式,那么只有值不為空就可以了
     if (strlen($pathPart) == 0) {
      return false;
     }
    } else {//如果對該變量需要滿足一個正則表達式,那么這里進行驗證
     $regex = $this->_regexDelimiter . '^' . $part['regex'] . '$' . $this->_regexDelimiter . 'iu';
     if (!preg_match($regex, $pathPart)) {
      return false;
     }
    }
    if ($name !== null) {
     // 如果是一個變量,則設置變量的值
     $this->_values[$name] = $pathPart;
     $unique[$name] = true; //其實沒有必要設置,這個版本根本就沒有用它
    } else {
     //把普通字符串的匹配計數加1,因為規則中的普通字符串是必須在path中存在的,否則就是
     //匹配失敗
     $pathStaticCount++;
    }
   }
  }
   //$this->_values中保存的是分析獲取的變量,如果規則中存在‘*',則$this->_params是獲取的
  //變量,否則是空數組,$this->_defaults是規則提供的默認變量值,這里用‘+'把三個數組相加
  //這樣的好處是如果后面的數組與前面的數組有相同的非整數的鍵值,后面的不會覆蓋前面的,這
  //與array_merge函數有區別,后者是會覆蓋的。也就是說,如果$this->_values 中已經有鍵controller
  //,那么$this->_defaults中的controller元素就被忽略,這樣就$this->_defaults中的默認值只有在path
  //中不存在的時候才會出現在返回值中。
  $return = $this->_values + $this->_params + $this->_defaults;
  // Check if all static mappings have been met
  if ($this->_staticCount != $pathStaticCount) {//規則的所有普通字符串必須在path中得到匹配
   return false;
  }
  // 解析完后,規則定義的所有變量也必須全部出現,否則視為不匹配
  foreach ($this->_vars as $var) {
   if (!array_key_exists($var, $return)) {
    return false;
   }
  }
  return $return;
}

以上是“Zend Framework框架路由機制的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

台南县| 兴文县| 淮北市| 新余市| 锡林郭勒盟| 龙州县| 尉犁县| 丽江市| 贵溪市| 天峨县| 平江县| 辉县市| 句容市| 承德县| 济源市| 通城县| 江西省| 沿河| 东兴市| 阿荣旗| 万全县| 巫溪县| 利辛县| 绥江县| 克什克腾旗| 库尔勒市| 宿州市| 修文县| 巧家县| 佛坪县| 娱乐| 诸暨市| 丰县| 台前县| 莱芜市| 德庆县| 明光市| 沁水县| 西城区| 纳雍县| 莱阳市|