亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > PHP > 正文

Zend Framework教程之請求對象的封裝Zend_Controller_Request實例詳解

2024-05-04 23:43:39
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了Zend Framework教程之請求對象的封裝Zend_Controller_Request用法,結合實例形式詳細分析了請求對象封裝的原理,使用方法與相關注意事項,需要的朋友可以參考下
 

本文實例講述了Zend Framework教程之請求對象的封裝Zend_Controller_Request方法。分享給大家供大家參考,具體如下:

概述

請求對象是在前端控制器,路由器,分發器,以及控制類間傳遞的簡單值對象。請求對象封裝了請求的模塊,控制器,動作以及可選的參數,還包括其他的請求環境,如HTTP,CLI,PHP-GTK。

請求對象的基本實現

├── Request
│   ├── Abstract.php
│   ├── Apache404.php
│   ├── Exception.php
│   ├── Http.php
│   ├── HttpTestCase.php
│   └── Simple.php

Zend_Controller_Request_Abstract

實現了請求對象的基本方法。

<?phpabstract class Zend_Controller_Request_Abstract{  protected $_dispatched = false;  protected $_module;  protected $_moduleKey = 'module';  protected $_controller;  protected $_controllerKey = 'controller';  protected $_action;  protected $_actionKey = 'action';  protected $_params = array();  public function getModuleName()  {    if (null === $this->_module) {      $this->_module = $this->getParam($this->getModuleKey());    }    return $this->_module;  }  public function setModuleName($value)  {    $this->_module = $value;    return $this;  }  public function getControllerName()  {    if (null === $this->_controller) {      $this->_controller = $this->getParam($this->getControllerKey());    }    return $this->_controller;  }  public function setControllerName($value)  {    $this->_controller = $value;    return $this;  }  public function getActionName()  {    if (null === $this->_action) {      $this->_action = $this->getParam($this->getActionKey());    }    return $this->_action;  }  public function setActionName($value)  {    $this->_action = $value;    /**     * @see ZF-3465     */    if (null === $value) {      $this->setParam($this->getActionKey(), $value);    }    return $this;  }  public function getModuleKey()  {    return $this->_moduleKey;  }  public function setModuleKey($key)  {    $this->_moduleKey = (string) $key;    return $this;  }  public function getControllerKey()  {    return $this->_controllerKey;  }  public function setControllerKey($key)  {    $this->_controllerKey = (string) $key;    return $this;  }  public function getActionKey()  {    return $this->_actionKey;  }  public function setActionKey($key)  {    $this->_actionKey = (string) $key;    return $this;  }  public function getParam($key, $default = null)  {    $key = (string) $key;    if (isset($this->_params[$key])) {      return $this->_params[$key];    }    return $default;  }  public function getUserParams()  {    return $this->_params;  }  public function getUserParam($key, $default = null)  {    if (isset($this->_params[$key])) {      return $this->_params[$key];    }    return $default;  }  public function setParam($key, $value)  {    $key = (string) $key;    if ((null === $value) && isset($this->_params[$key])) {      unset($this->_params[$key]);    } elseif (null !== $value) {      $this->_params[$key] = $value;    }    return $this;  }   public function getParams()   {     return $this->_params;   }  public function setParams(array $array)  {    $this->_params = $this->_params + (array) $array;    foreach ($array as $key => $value) {      if (null === $value) {        unset($this->_params[$key]);      }    }    return $this;  }  public function clearParams()  {    $this->_params = array();    return $this;  }  public function setDispatched($flag = true)  {    $this->_dispatched = $flag ? true : false;    return $this;  }  public function isDispatched()  {    return $this->_dispatched;  }}

Zend_Controller_Request_Http

Zend_Controller_Request請求對象的默認實現。

<?phprequire_once 'Zend/Controller/Request/Abstract.php';require_once 'Zend/Uri.php';class Zend_Controller_Request_Http extends Zend_Controller_Request_Abstract{  const SCHEME_HTTP = 'http';  const SCHEME_HTTPS = 'https';  protected $_paramSources = array('_GET', '_POST');  protected $_requestUri;  protected $_baseUrl = null;  protected $_basePath = null;  protected $_pathInfo = '';  protected $_params = array();  protected $_rawBody;  protected $_aliases = array();  public function __construct($uri = null)  {    if (null !== $uri) {      if (!$uri instanceof Zend_Uri) {        $uri = Zend_Uri::factory($uri);      }      if ($uri->valid()) {        $path = $uri->getPath();        $query = $uri->getQuery();        if (!empty($query)) {          $path .= '?' . $query;        }        $this->setRequestUri($path);      } else {        require_once 'Zend/Controller/Request/Exception.php';        throw new Zend_Controller_Request_Exception('Invalid URI provided to constructor');      }    } else {      $this->setRequestUri();    }  }  public function __get($key)  {    switch (true) {      case isset($this->_params[$key]):        return $this->_params[$key];      case isset($_GET[$key]):        return $_GET[$key];      case isset($_POST[$key]):        return $_POST[$key];      case isset($_COOKIE[$key]):        return $_COOKIE[$key];      case ($key == 'REQUEST_URI'):        return $this->getRequestUri();      case ($key == 'PATH_INFO'):        return $this->getPathInfo();      case isset($_SERVER[$key]):        return $_SERVER[$key];      case isset($_ENV[$key]):        return $_ENV[$key];      default:        return null;    }  }  public function get($key)  {    return $this->__get($key);  }  public function __set($key, $value)  {    require_once 'Zend/Controller/Request/Exception.php';    throw new Zend_Controller_Request_Exception('Setting values in superglobals not allowed; please use setParam()');  }  public function set($key, $value)  {    return $this->__set($key, $value);  }  public function __isset($key)  {    switch (true) {      case isset($this->_params[$key]):        return true;      case isset($_GET[$key]):        return true;      case isset($_POST[$key]):        return true;      case isset($_COOKIE[$key]):        return true;      case isset($_SERVER[$key]):        return true;      case isset($_ENV[$key]):        return true;      default:        return false;    }  }  public function has($key)  {    return $this->__isset($key);  }  public function setQuery($spec, $value = null)  {    if ((null === $value) && !is_array($spec)) {      require_once 'Zend/Controller/Exception.php';      throw new Zend_Controller_Exception('Invalid value passed to setQuery(); must be either array of values or key/value pair');    }    if ((null === $value) && is_array($spec)) {      foreach ($spec as $key => $value) {        $this->setQuery($key, $value);      }      return $this;    }    $_GET[(string) $spec] = $value;    return $this;  }  public function getQuery($key = null, $default = null)  {    if (null === $key) {      return $_GET;    }    return (isset($_GET[$key])) ? $_GET[$key] : $default;  }  public function setPost($spec, $value = null)  {    if ((null === $value) && !is_array($spec)) {      require_once 'Zend/Controller/Exception.php';      throw new Zend_Controller_Exception('Invalid value passed to setPost(); must be either array of values or key/value pair');    }    if ((null === $value) && is_array($spec)) {      foreach ($spec as $key => $value) {        $this->setPost($key, $value);      }      return $this;    }    $_POST[(string) $spec] = $value;    return $this;  }  public function getPost($key = null, $default = null)  {    if (null === $key) {      return $_POST;    }    return (isset($_POST[$key])) ? $_POST[$key] : $default;  }  public function getCookie($key = null, $default = null)  {    if (null === $key) {      return $_COOKIE;    }    return (isset($_COOKIE[$key])) ? $_COOKIE[$key] : $default;  }  public function getServer($key = null, $default = null)  {    if (null === $key) {      return $_SERVER;    }    return (isset($_SERVER[$key])) ? $_SERVER[$key] : $default;  }  public function getEnv($key = null, $default = null)  {    if (null === $key) {      return $_ENV;    }    return (isset($_ENV[$key])) ? $_ENV[$key] : $default;  }  public function setRequestUri($requestUri = null)  {    if ($requestUri === null) {      if (isset($_SERVER['HTTP_X_REWRITE_URL'])) { // check this first so IIS will catch        $requestUri = $_SERVER['HTTP_X_REWRITE_URL'];      } elseif (        // IIS7 with URL Rewrite: make sure we get the unencoded url (double slash problem)        isset($_SERVER['IIS_WasUrlRewritten'])        && $_SERVER['IIS_WasUrlRewritten'] == '1'        && isset($_SERVER['UNENCODED_URL'])        && $_SERVER['UNENCODED_URL'] != ''        ) {        $requestUri = $_SERVER['UNENCODED_URL'];      } elseif (isset($_SERVER['REQUEST_URI'])) {        $requestUri = $_SERVER['REQUEST_URI'];        // Http proxy reqs setup request uri with scheme and host [and port] + the url path, only use url path        $schemeAndHttpHost = $this->getScheme() . '://' . $this->getHttpHost();        if (strpos($requestUri, $schemeAndHttpHost) === 0) {          $requestUri = substr($requestUri, strlen($schemeAndHttpHost));        }      } elseif (isset($_SERVER['ORIG_PATH_INFO'])) { // IIS 5.0, PHP as CGI        $requestUri = $_SERVER['ORIG_PATH_INFO'];        if (!empty($_SERVER['QUERY_STRING'])) {          $requestUri .= '?' . $_SERVER['QUERY_STRING'];        }      } else {        return $this;      }    } elseif (!is_string($requestUri)) {      return $this;    } else {      // Set GET items, if available      if (false !== ($pos = strpos($requestUri, '?'))) {        // Get key => value pairs and set $_GET        $query = substr($requestUri, $pos + 1);        parse_str($query, $vars);        $this->setQuery($vars);      }    }    $this->_requestUri = $requestUri;    return $this;  }  public function getRequestUri()  {    if (empty($this->_requestUri)) {      $this->setRequestUri();    }    return $this->_requestUri;  }  public function setBaseUrl($baseUrl = null)  {    if ((null !== $baseUrl) && !is_string($baseUrl)) {      return $this;    }    if ($baseUrl === null) {      $filename = (isset($_SERVER['SCRIPT_FILENAME'])) ? basename($_SERVER['SCRIPT_FILENAME']) : '';      if (isset($_SERVER['SCRIPT_NAME']) && basename($_SERVER['SCRIPT_NAME']) === $filename) {        $baseUrl = $_SERVER['SCRIPT_NAME'];      } elseif (isset($_SERVER['PHP_SELF']) && basename($_SERVER['PHP_SELF']) === $filename) {        $baseUrl = $_SERVER['PHP_SELF'];      } elseif (isset($_SERVER['ORIG_SCRIPT_NAME']) && basename($_SERVER['ORIG_SCRIPT_NAME']) === $filename) {        $baseUrl = $_SERVER['ORIG_SCRIPT_NAME']; // 1and1 shared hosting compatibility      } else {        // Backtrack up the script_filename to find the portion matching        // php_self        $path  = isset($_SERVER['PHP_SELF']) ? $_SERVER['PHP_SELF'] : '';        $file  = isset($_SERVER['SCRIPT_FILENAME']) ? $_SERVER['SCRIPT_FILENAME'] : '';        $segs  = explode('/', trim($file, '/'));        $segs  = array_reverse($segs);        $index  = 0;        $last  = count($segs);        $baseUrl = '';        do {          $seg   = $segs[$index];          $baseUrl = '/' . $seg . $baseUrl;          ++$index;        } while (($last > $index) && (false !== ($pos = strpos($path, $baseUrl))) && (0 != $pos));      }      // Does the baseUrl have anything in common with the request_uri?      $requestUri = $this->getRequestUri();      if (0 === strpos($requestUri, $baseUrl)) {        // full $baseUrl matches        $this->_baseUrl = $baseUrl;        return $this;      }      if (0 === strpos($requestUri, dirname($baseUrl))) {        // directory portion of $baseUrl matches        $this->_baseUrl = rtrim(dirname($baseUrl), '/');        return $this;      }      $truncatedRequestUri = $requestUri;      if (($pos = strpos($requestUri, '?')) !== false) {        $truncatedRequestUri = substr($requestUri, 0, $pos);      }      $basename = basename($baseUrl);      if (empty($basename) || !strpos($truncatedRequestUri, $basename)) {        // no match whatsoever; set it blank        $this->_baseUrl = '';        return $this;      }      // If using mod_rewrite or ISAPI_Rewrite strip the script filename      // out of baseUrl. $pos !== 0 makes sure it is not matching a value      // from PATH_INFO or QUERY_STRING      if ((strlen($requestUri) >= strlen($baseUrl))        && ((false !== ($pos = strpos($requestUri, $baseUrl))) && ($pos !== 0)))      {        $baseUrl = substr($requestUri, 0, $pos + strlen($baseUrl));      }    }    $this->_baseUrl = rtrim($baseUrl, '/');    return $this;  }  public function getBaseUrl($raw = false)  {    if (null === $this->_baseUrl) {      $this->setBaseUrl();    }    return (($raw == false) ? urldecode($this->_baseUrl) : $this->_baseUrl);  }  public function setBasePath($basePath = null)  {    if ($basePath === null) {      $filename = (isset($_SERVER['SCRIPT_FILENAME']))           ? basename($_SERVER['SCRIPT_FILENAME'])           : '';      $baseUrl = $this->getBaseUrl();      if (empty($baseUrl)) {        $this->_basePath = '';        return $this;      }      if (basename($baseUrl) === $filename) {        $basePath = dirname($baseUrl);      } else {        $basePath = $baseUrl;      }    }    if (substr(PHP_OS, 0, 3) === 'WIN') {      $basePath = str_replace('//', '/', $basePath);    }    $this->_basePath = rtrim($basePath, '/');    return $this;  }  public function getBasePath()  {    if (null === $this->_basePath) {      $this->setBasePath();    }    return $this->_basePath;  }  public function setPathInfo($pathInfo = null)  {    if ($pathInfo === null) {      $baseUrl = $this->getBaseUrl(); // this actually calls setBaseUrl() & setRequestUri()      $baseUrlRaw = $this->getBaseUrl(false);      $baseUrlEncoded = urlencode($baseUrlRaw);      if (null === ($requestUri = $this->getRequestUri())) {        return $this;      }      // Remove the query string from REQUEST_URI      if ($pos = strpos($requestUri, '?')) {        $requestUri = substr($requestUri, 0, $pos);      }      if (!empty($baseUrl) || !empty($baseUrlRaw)) {        if (strpos($requestUri, $baseUrl) === 0) {          $pathInfo = substr($requestUri, strlen($baseUrl));        } elseif (strpos($requestUri, $baseUrlRaw) === 0) {          $pathInfo = substr($requestUri, strlen($baseUrlRaw));        } elseif (strpos($requestUri, $baseUrlEncoded) === 0) {          $pathInfo = substr($requestUri, strlen($baseUrlEncoded));        } else {          $pathInfo = $requestUri;        }      } else {        $pathInfo = $requestUri;      }    }    $this->_pathInfo = (string) $pathInfo;    return $this;  }  public function getPathInfo()  {    if (empty($this->_pathInfo)) {      $this->setPathInfo();    }    return $this->_pathInfo;  }  public function setParamSources(array $paramSources = array())  {    $this->_paramSources = $paramSources;    return $this;  }  public function getParamSources()  {    return $this->_paramSources;  }  public function setParam($key, $value)  {    $key = (null !== ($alias = $this->getAlias($key))) ? $alias : $key;    parent::setParam($key, $value);    return $this;  }  public function getParam($key, $default = null)  {    $keyName = (null !== ($alias = $this->getAlias($key))) ? $alias : $key;    $paramSources = $this->getParamSources();    if (isset($this->_params[$keyName])) {      return $this->_params[$keyName];    } elseif (in_array('_GET', $paramSources) && (isset($_GET[$keyName]))) {      return $_GET[$keyName];    } elseif (in_array('_POST', $paramSources) && (isset($_POST[$keyName]))) {      return $_POST[$keyName];    }    return $default;  }  public function getParams()  {    $return    = $this->_params;    $paramSources = $this->getParamSources();    if (in_array('_GET', $paramSources)      && isset($_GET)      && is_array($_GET)    ) {      $return += $_GET;    }    if (in_array('_POST', $paramSources)      && isset($_POST)      && is_array($_POST)    ) {      $return += $_POST;    }    return $return;  }  public function setParams(array $params)  {    foreach ($params as $key => $value) {      $this->setParam($key, $value);    }    return $this;  }  public function setAlias($name, $target)  {    $this->_aliases[$name] = $target;    return $this;  }  public function getAlias($name)  {    if (isset($this->_aliases[$name])) {      return $this->_aliases[$name];    }    return null;  }  public function getAliases()  {    return $this->_aliases;  }  public function getMethod()  {    return $this->getServer('REQUEST_METHOD');  }  public function isPost()  {    if ('POST' == $this->getMethod()) {      return true;    }    return false;  }  public function isGet()  {    if ('GET' == $this->getMethod()) {      return true;    }    return false;  }  public function isPut()  {    if ('PUT' == $this->getMethod()) {      return true;    }    return false;  }  public function isDelete()  {    if ('DELETE' == $this->getMethod()) {      return true;    }    return false;  }  public function isHead()  {    if ('HEAD' == $this->getMethod()) {      return true;    }    return false;  }  public function isOptions()  {    if ('OPTIONS' == $this->getMethod()) {      return true;    }    return false;  }  public function isXmlHttpRequest()  {    return ($this->getHeader('X_REQUESTED_WITH') == 'XMLHttpRequest');  }  public function isFlashRequest()  {    $header = strtolower($this->getHeader('USER_AGENT'));    return (strstr($header, ' flash')) ? true : false;  }  public function isSecure()  {    return ($this->getScheme() === self::SCHEME_HTTPS);  }  public function getRawBody()  {    if (null === $this->_rawBody) {      $body = file_get_contents('php://input');      if (strlen(trim($body)) > 0) {        $this->_rawBody = $body;      } else {        $this->_rawBody = false;      }    }    return $this->_rawBody;  }  public function getHeader($header)  {    if (empty($header)) {      require_once 'Zend/Controller/Request/Exception.php';      throw new Zend_Controller_Request_Exception('An HTTP header name is required');    }    // Try to get it from the $_SERVER array first    $temp = 'HTTP_' . strtoupper(str_replace('-', '_', $header));    if (isset($_SERVER[$temp])) {      return $_SERVER[$temp];    }    // This seems to be the only way to get the Authorization header on    // Apache    if (function_exists('apache_request_headers')) {      $headers = apache_request_headers();      if (isset($headers[$header])) {        return $headers[$header];      }      $header = strtolower($header);      foreach ($headers as $key => $value) {        if (strtolower($key) == $header) {          return $value;        }      }    }    return false;  }  public function getScheme()  {    return ($this->getServer('HTTPS') == 'on') ? self::SCHEME_HTTPS : self::SCHEME_HTTP;  }  public function getHttpHost()  {    $host = $this->getServer('HTTP_HOST');    if (!empty($host)) {      return $host;    }    $scheme = $this->getScheme();    $name  = $this->getServer('SERVER_NAME');    $port  = $this->getServer('SERVER_PORT');    if(null === $name) {      return '';    }    elseif (($scheme == self::SCHEME_HTTP && $port == 80) || ($scheme == self::SCHEME_HTTPS && $port == 443)) {      return $name;    } else {      return $name . ':' . $port;    }  }  public function getClientIp($checkProxy = true)  {    if ($checkProxy && $this->getServer('HTTP_CLIENT_IP') != null) {      $ip = $this->getServer('HTTP_CLIENT_IP');    } else if ($checkProxy && $this->getServer('HTTP_X_FORWARDED_FOR') != null) {      $ip = $this->getServer('HTTP_X_FORWARDED_FOR');    } else {      $ip = $this->getServer('REMOTE_ADDR');    }    return $ip;  }}

從上述類的實現,不難看出,類為我們提供了很多方便的方法來獲取需要的數據。例如:

模塊名可通過getModuleName()和setModuleName()訪問。
控制器名可通過getControllerName()和setControllerName()訪問。
控制器調用的動作名稱可通過getActionName()和setActionName()訪問。
可訪問的參數是一個鍵值對的關聯數組。數組可通過getParams()和 setParams()獲取及設置,單個參數可以通過 getParam() 和 setParam()獲取及設置。

基于請求的類型存在更多的可用方法。默認的Zend_Controller_Request_Http請求對象,擁有訪問請求url、路徑信息、$_GET 和 $_POST參數的方法等等。

請求對象先被傳入到前端控制器。如果沒有提供請求對象,它將在分發過程的開始、任何路由過程發生之前實例化。請求對象將被傳遞到分發鏈中的每個對象。

而且,請求對象在測試中是很有用的。開發人員可根據需要搭建請求環境,包括模塊、控制器、動作、參數、URI等等,并且將其傳入前端控制器來測試程序流向。如果與響應對象配合,可以對MVC程序進行精確巧妙的單元測試(unit testing)。

HTTP 請求

訪問請求數據

Zend_Controller_Request_Http封裝了對相關值的訪問,如控制器和動作路由器變量的鍵名和值,從URL解析的附加參數。它還允許訪問作為公共成員的超全局變量,管理當前的基地址(Base URL)和請求URI。超全局變量不能在請求對象中賦值,但可以通過setParam/getParam方法設定/獲取用戶參數。

Note: 超全局數據

通過Zend_Controller_Request_Http訪問公共成員屬性的超全局數據,有必要認識到一點,這些屬性名(超全局數組的鍵)按照特定次序匹配超全局變量:1. GET,2.POST,3. COOKIE,4. SERVER,5. ENV。

特定的超全局變量也可以選擇特定的方法來訪問,如$_POST['user']可以調用請求對象的getPost('user')訪問,getQuery()可以獲取$_GET元素,getHeader()可以獲取請求消息頭。

Note: GET和POST數據

需要注意:在請求對象中訪問數據是沒有經過任何過濾的,路由器和分發器根據任務來驗證過濾數據,但在請求對象中沒有任何處理。

Note: 也獲取原始 (Raw) POST 數據!

從 1.5.0 開始,也可以通過 getRawBody() 方法獲取原始 post 數據。如果沒有數據以那種方式提交,該方法返回 false,但 post 的全體(full boday)是個例外。

當開發一個 RESTful MVC 程序,這個對于接受內容相當有用。

可以在請求對象中使用setParam() 和getParam()來設置和獲取用戶參數。 路由器根據請求URI中的參數,利用這項功能請求對象設定參數。

Note: getParam()不只可以獲取用戶參數

getParam()事實上從幾個資源中獲取參數。根據優先級排序:通過setParam()設置的用戶參數,GET 參數,最后是POST參數。 通過該方法獲取數據時需要注意這點。

如果你希望從你通過 setParam() 設置的參數中獲?。▍担褂?getUserParam()。

另外,從 1.5.0 開始,可以鎖定搜索哪個參數源,setParamSources() 允許指定一個空數組或者一個帶有一個或多個指示哪個參數源被允許(缺省兩者都被允許)的值 '_GET'或'_POST'的數組;如果想限制只訪問 '_GET',那么指定 setParamSources(array('_GET')) 。

Note: Apache相關

如果使用apache的404處理器來傳遞請求到前端控制器,或者使用重寫規則(rewrite rules)的PT標志,URI包含在$_SERVER['REDIRECT_URL'],而不是$_SERVER['REQUEST_URI']。如果使用這樣的設定并獲取無效的路由,應該使用Zend_Controller_Request_Apache404類代替默認的HTTP類:

$request = new Zend_Controller_Request_Apache404();$front->setRequest($request);

這個類繼承了Zend_Controller_Request_Http,并簡單的修改了請求URI的自動發現(autodiscovery),它可以用來作為簡易替換器件(drop-in replacement)。
基地址和子目錄

Zend_Controller_Request_Http允許在子目錄中使用Zend_Controller_Router_Rewrite。Zend_Controller_Request_Http試圖自動的檢測你的基地址,并進行相應的設置。

例如,如果將 index.php 放在web服務器的名為/projects/myapp/index.php子目錄中,基地址應該被設置為/projects/myapp。計算任何路由匹配之前將先從路徑中去除這個字符串。這個字串需要被加入到任何路由前面。路由 'user/:username'將匹配類似http://localhost/projects/myapp/user/martel 和http://example.com/user/martel的URL。

Note: URL檢測區分大小寫

基地址的自動檢測是區分大小寫的,因此需要確保URL與文件系統中的子目錄匹配。否則將會引發異常。

如果基地址經檢測不正確,可以利用Zend_Controller_Request_Http或者Zend_Controller_Front類的setBaseUrl()方法設置自己的基路徑。Zend_Controller_Front設置最容易,它將導入基地址到請求對象。定制基地址的用法舉例:

/** * Dispatch Request with custom base URL with Zend_Controller_Front. */$router   = new Zend_Controller_Router_Rewrite();$controller = Zend_Controller_Front::getInstance();$controller->setControllerDirectory('./application/controllers')      ->setRouter($router)      ->setBaseUrl('/projects/myapp'); // set the base url!$response  = $controller->dispatch();

判斷請求方式

getMethod() 允許你決定用于請求當前資源的 HTTP 請求方法。另外,當詢問是否一個請求的特定類型是否已經存在,有許多方法允許你獲得布爾響應:

isGet()
isPost()
isPut()
isDelete()
isHead()
isOptions()

這些基本用例是來創建 RESTful MVC 架構的。

AJAX 請求

Zend_Controller_Request_Http 有一個初步的方法用來檢測AJAX請求:isXmlHttpRequest()。這個方法尋找一個帶有'XMLHttpRequest' 值的HTTP請求頭X-Requested-With;如果發現,就返回true。

當前,這個頭用下列JS庫缺省地傳遞:
Prototype/Scriptaculous (and libraries derived from Prototype)
Yahoo! UI Library
jQuery
MochiKit

大多數 AJAX 庫允許發送定制的HTTP請求頭;如果你的庫沒有發送這個頭,簡單地把它作為一個請求頭添加上確保isXmlHttpRequest() 方法工作。
子類化請求對象。

請求對象是請求環境的容器??刂破麈湆嶋H上只需要知道如何設置和獲取控制器、動作,可選的參數以及分發的狀態。默認的,請求將使用controller和action鍵查詢自己的參數來確定控制器和動作。

需要一個請求類來與特定的環境交互以獲得需要的數據時,可以擴展該基類或它的衍生類。例如HTTP環境,CLI環境,或者PHP-GTK環境。



注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
y97精品国产97久久久久久| 久久大大胆人体| 成人免费网站在线| 久久精品久久久久电影| 亚洲欧美日韩久久久久久| 国产九九精品视频| 国产亚洲精品美女| 久久久极品av| 欧美激情在线播放| 午夜欧美不卡精品aaaaa| 欧洲亚洲妇女av| 亚洲精品午夜精品| 国产精品天天狠天天看| 国产精品美女在线| 亚洲最大的免费| 国产精品久久久久99| 国产精品美女在线| 国产精品伦子伦免费视频| 久久伊人91精品综合网站| 日韩亚洲国产中文字幕| 久久久久久久一区二区三区| 国产精品无av码在线观看| 亚洲精品美女视频| 精品久久久久久中文字幕大豆网| 黄色一区二区在线观看| 欧美大片在线看免费观看| 91精品在线影院| 欧美黑人性生活视频| 久久久久久久久久久久av| 亚洲成色777777在线观看影院| 欧美在线亚洲一区| 国产精品久久久久久久久久免费| 国产欧美精品一区二区三区介绍| 久久男人的天堂| 国模gogo一区二区大胆私拍| 国产精品久久9| 欧美一区二区三区精品电影| 国产一区二区在线免费视频| 亚洲2020天天堂在线观看| 中文国产成人精品久久一| 欧美第一黄网免费网站| 狠狠色狠狠色综合日日五| 日韩精品免费观看| 欧美大胆在线视频| 国产91精品在线播放| 亚洲视频视频在线| 国产精品亚洲网站| 57pao精品| 亚洲欧美综合图区| 欧美孕妇与黑人孕交| 欧美综合在线观看| 成人午夜激情免费视频| 日韩av电影手机在线观看| 久久精品久久久久久| 成人黄色片在线| 欧美福利小视频| 国产一区二区日韩| 日韩欧美在线国产| 久久久久久久香蕉网| 亚洲第一精品电影| 欧美国产日产韩国视频| 亚洲福利视频在线| 欧美国产亚洲视频| 91视频国产高清| 亚洲精品自产拍| 久久久久久久久久久久久久久久久久av| 在线中文字幕日韩| 国产香蕉97碰碰久久人人| 亚洲人成77777在线观看网| 成人免费黄色网| 精品久久久久久久久久国产| 欧美成年人视频网站欧美| 国模精品视频一区二区| 亚洲精品久久久久中文字幕二区| 亚洲精品久久久久| 国产精品亚洲一区二区三区| 日韩电影免费在线观看中文字幕| 日本精品一区二区三区在线播放视频| 亚洲男人的天堂在线| 欧美性xxxx18| 国产视频福利一区| 亚洲国产一区二区三区四区| 亚洲第一网站男人都懂| 米奇精品一区二区三区在线观看| 日本一区二区在线免费播放| 91老司机精品视频| 国产日韩精品在线播放| 久久国产精品久久国产精品| 7777免费精品视频| 亚洲精品国产精品久久清纯直播| 国产成人aa精品一区在线播放| 国产精品啪视频| 在线看日韩欧美| 久久在精品线影院精品国产| 欧美伊久线香蕉线新在线| 国产97在线播放| 国产精品国语对白| 欧美日韩性生活视频| 青草热久免费精品视频| 欧美日韩裸体免费视频| 国内外成人免费激情在线视频| 亚洲风情亚aⅴ在线发布| 欧美电影第一页| 久久久精品国产| 成人精品在线视频| 亚洲一区二区三区视频播放| 九九九热精品免费视频观看网站| 91美女片黄在线观| 日韩经典中文字幕在线观看| 日韩久久午夜影院| 一本色道久久88亚洲综合88| 中文字幕亚洲自拍| 精品视频一区在线视频| 欧美激情综合色| 国产精品偷伦免费视频观看的| 亚洲激情视频在线| 亚洲精品suv精品一区二区| 欧美日韩国产限制| 精品国产网站地址| 国产精品第2页| 成人免费观看49www在线观看| 亚洲国产成人久久综合| 色综合久久88色综合天天看泰| 在线亚洲午夜片av大片| 久久精品一偷一偷国产| 久久国产精品亚洲| 久久精品久久久久电影| 亚洲国产中文字幕在线观看| 日韩黄在线观看| 欧美亚洲伦理www| 九九精品视频在线| 色综合亚洲精品激情狠狠| 福利微拍一区二区| 亚洲精品国产精品国自产在线| 欧美亚洲另类视频| 中文字幕免费精品一区高清| 亚洲精品综合精品自拍| 91精品啪aⅴ在线观看国产| 欧日韩不卡在线视频| 北条麻妃99精品青青久久| 一本色道久久综合狠狠躁篇怎么玩| 国产91av在线| 色阁综合伊人av| 精品中文字幕在线2019| 4p变态网欧美系列| 亚洲精美色品网站| 久久久久久亚洲精品中文字幕| 日韩在线免费观看视频| 国产成+人+综合+亚洲欧洲| 日韩在线视频二区| 91国产美女在线观看| 国产性猛交xxxx免费看久久| 日韩美女免费观看| 久久亚洲精品国产亚洲老地址| 国产香蕉精品视频一区二区三区| 欧美亚洲另类视频| 欧美视频在线免费| 成人精品网站在线观看| 久久影视电视剧免费网站| 91亚洲精品久久久久久久久久久久| 亚洲肉体裸体xxxx137| 96pao国产成视频永久免费| 欧美一区二区三区……| 欧美精品久久久久久久久久|