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

首頁 > 開發(fā) > PHP > 正文

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

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

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

概述

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

請求對象的基本實現(xiàn)

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

Zend_Controller_Request_Abstract

實現(xiàn)了請求對象的基本方法。

<?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請求對象的默認實現(xiàn)。

<?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;  }}

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

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

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

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

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

HTTP 請求

訪問請求數(shù)據(jù)

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

Note: 超全局數(shù)據(jù)

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

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

Note: GET和POST數(shù)據(jù)

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

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

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

當開發(fā)一個 RESTful MVC 程序,這個對于接受內(nèi)容相當有用。

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

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

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

如果你希望從你通過 setParam() 設(shè)置的參數(shù)中獲取(參數(shù)),使用 getUserParam()。

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

Note: Apache相關(guān)

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

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

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

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

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

Note: URL檢測區(qū)分大小寫

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

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

/** * 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 請求方法。另外,當詢問是否一個請求的特定類型是否已經(jīng)存在,有許多方法允許你獲得布爾響應(yīng):

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

這些基本用例是來創(chuàng)建 RESTful MVC 架構(gòu)的。

AJAX 請求

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

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

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

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

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



注:相關(guān)教程知識閱讀請移步到PHP教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
999视频在线观看| 人人干人人爱人人爱| 中国一级大黄大黄大色毛片| 国产精品女同互慰在线看| 久久综合五月天| 国产高清免费av| 欧美精品综合| 色在线免费观看| 欧美—级在线免费片| 日韩国产欧美亚洲| av资源中文在线天堂| 亚洲天堂视频在线| 精品久久久一区二区| 黄色在线免费| 99久久久久久99| 国产视频中文字幕在线观看| 日本人妻一区二区三区| 久久高清视频免费| 黄色91在线观看| 成人av动漫在线观看| 成人欧美一区二区三区在线播放| 蜜桃av鲁一鲁一鲁一鲁俄罗斯的| 欧美黑人双插| 国产精品女同互慰在线看| 国产一级特黄a大片99| 国内老熟妇对白xxxxhd| 色影视在线视频资源站| 欧美日韩国产专区| 成人动漫在线视频| 国产黄色免费看| 国内成+人亚洲+欧美+综合在线| 亚洲产国偷v产偷v自拍涩爱| 中文久久乱码一区二区| 久久久久久亚洲中文字幕无码| 亚洲一区观看| 成人黄色av片| 国产午夜无码视频在线观看| 成人黄色在线网站| 色婷婷激情一区二区三区| 五十路亲子中出中文字幕| 日韩欧美一区二区三区| 加勒比一区二区三区在线| 久久精品人妻一区二区三区| 1234区在线观看视频免费| 最新97超碰在线| 国产一区二区三区视频播放| 香蕉成人久久| 欧洲亚洲精品在线| 亚洲成人精品电影在线观看| 欧美三级电影一区| 视频一区免费在线观看| 波多野结衣视频在线看| 精品噜噜噜噜久久久久久久久试看| 亚洲风情在线资源| 午夜日韩在线观看| 精品人妻无码中文字幕18禁| 视频一区二区在线播放| 日韩在线第三页| 国产成人无码一区二区在线观看| 99久久99久久精品免费| 99re6热只有精品免费观看| 亚洲国产网站| 免费观看亚洲| 狠狠色综合网| 91精品国产视频| 国产精品久久免费| 中文字幕在线不卡国产视频| 9999在线视频| 午夜在线小视频| 女人裸体性做爰全过| 午夜在线a亚洲v天堂网2018| 麻豆传传媒久久久爱| 亚洲国产精品专区久久| 欧美精品一区二区三区蜜桃| 丁香5月婷婷久久| 亚洲一区二区免费在线| sese视频| 国产原创在线| 日韩在线观看一区二区三区| 一级全黄少妇性色生活片| 日韩一区二区三区电影在线观看| 丁香花高清在线观看完整版| 欧美色图激情小说| 污视频网站免费在线观看| 亚洲伊人网在线观看| 国产精品二三区| 久久综合伊人77777麻豆| 午夜精品视频在线观看一区二区| 2020国产精品自拍| 亚洲视频精品一区| 日本不卡免费高清视频在线| 亚洲一区二区三区香蕉| 欧美极品中文字幕| 最新四虎影在线在永久观看www| 亚洲无亚洲人成网站77777| 久久精品2019中文字幕| 欧美日韩午夜视频| 精品精品导航| 久久―日本道色综合久久| 欧美国产综合一区二区| 成人激情春色网| 亚洲精品18| 精品视频二区三区| 久久久成人av毛片免费观看| 91伊人久久| 久久久久久久久久久久久国产精品| 免费成人性网站| 日本高清视频免费观看| 在线精品国产成人综合| 天天综合天天| 神马久久桃色视频| 四季av一区二区凹凸精品| 亚洲高清色图| 欧美日韩亚洲免费| 97精品一区| 91野花视频| 日本韩国欧美在线| 精品成人a区在线观看| 天天碰免费视频| 性xxxx18| 国产男小鲜肉同志免费| 国产三级在线免费观看| 久久亚洲av午夜福利精品一区| 日本护士做爰视频| 男人天堂网在线观看| 中文字幕不卡免费视频| 人妻少妇无码精品视频区| 国产成人精品免费看| 亚洲影音先锋| 日韩国产成人在线| 成年人国产在线观看| 欧美性猛交ⅹxxx乱大交免费| 亚洲一区二区蜜桃| 黄页网站大全在线免费观看| 中文字幕日韩经典| 天堂精品久久久久| 日韩最新av在线| 久久国产精品99久久人人澡| 男人猛进猛出女人屁股视频| 亚洲欧美日韩国产综合在线| 欧美不卡视频| 妞干网2018| 亚洲第一色网| 欧美日韩亚洲一区二区三区四区| 无码 人妻 在线 视频| 91精品国产综合久久久久久久久久| 蜜臀99久久精品久久久久久软件| 亚洲黄色在线| 国产精品高潮呻吟久久av无限| 91精品国偷自产在线电影| 久草手机在线视频| 亚洲欧美国产77777| a级日韩大片| 久久蜜桃香蕉精品一区二区三区| 狠狠干夜夜草| 亚洲日本视频在线| 日本女优天堂99伊人| 日日夜夜亚洲精品| 九色精品高清在线播放| 国产精品美女999| 国产日产欧美视频| 精品不卡一区二区三区| 国产一区二区日韩| 亚洲电影av| 欧美一级电影在线| 可以免费看av的网址| 国产精品偷伦视频免费观看了| 成人三级视频在线观看一区二区| 久久日韩精品一区二区五区| 国产精品无码一区二区桃花视频| 欧美成人免费在线观看视频| 亚洲欧美自拍视频| 一区二区亚洲精品国产| 色女人在线视频| 97人摸人人澡人人人超一碰| 第一页在线观看| 蜜桃视频在线观看成人| 久久理论片午夜琪琪电影网| 全部av―极品视觉盛宴亚洲| 国产传媒在线观看| 91免费精品国偷自产在线| 国产精品综合不卡av| 亚洲一区二区三区四区电影| 性欧美18xxxhd| 成人免费视频网站入口::| 午夜精品无码一区二区三区| 99久久精品国产一区二区三区| 91国产一区| 成人在线免费av| 狠狠躁夜夜躁人人躁婷婷91| www毛片com| 日本免费一区二区三区四区| 狠狠色综合一区二区| 可以免费看污视频的网站在线| 中日韩免费视频中文字幕| 天天综合成人网| www.色就是色| 欧美一区二区三区公司| 日韩大片在线观看视频| eeuss影院18www免费| 91av成人在线| 日韩av手机在线播放| 亚洲黄色av| 波多野结衣先锋影音| 美女在线观看www| 色网站免费观看| 亚洲精品蜜桃乱晃| 日韩欧美一区二区三区视频| 国产亚洲精品美女久久久久久久久久| 91在线色戒在线| 亚洲色无码播放| 国产最新精品免费| 国产一区二区三区美女秒播| 国产精品一区二区久激情瑜伽| 亚洲日本色图| 国产一级特黄视频| 国产伦精品一区二区三区视频金莲| 国产精品久久久久久av下载红粉| 五月天婷婷激情视频| 国产精品视频自拍| 国产亚洲精品精品国产亚洲综合| 成人免费网视频| 成人高潮片免费视频| 一区二区三区www污污污网站| 国产理论视频在线观看| 精品欧美色视频网站在线观看| 99久久.com| 清纯唯美一区二区三区| 91在线资源| 国产盗摄精品一区二区酒店| 成人综合婷婷国产精品久久蜜臀| 精品国产免费人成电影在线观...| 国内精品视频一区二区三区| 久久偷看各类wc女厕嘘嘘偷窃| 日韩不卡一二三区| 国产成人免费网站| 黄色一区二区三区四区| 久久免费视频这里只有精品| 一级一级黄色片| 亚洲视频一区二区| 中国美女黄色一级片| 久久久久久免费视频| 国产精品16p| 精品久久综合| 天堂一区二区三区| 国产日韩视频在线| 视频一区视频二区在线观看| 91午夜交换视频| 国产字幕在线观看| www.91视频| 亚洲国内高清视频| 天堂v视频永久在线播放| 国产91丝袜在线播放九色| 精品亚洲一区二区三区四区| 在线观看免费成人av| 艹b视频在线观看| 欧产日产国产精品视频| 2020久久国产精品| 韩国久久久久| 欧美激情一区二区三区全黄| 97av在线影院| 亚洲最黄网站| 99精品国产九九国产精品| 国产成人精品一区二区三区在线观看| 亚洲在线国产日韩欧美| 久久国产精品无码一级毛片| 成人免费网站www网站高清| 国产精品美女一区二区| 97人人模人人爽视频一区二区| 亚洲视频一区二区在线| 欧美午夜在线播放| 人妻精品久久久久中文字幕| 国产成人av一区二区三区| 国产98在线|日韩| 精品国产乱码久久久久久久软件| 国产精品女主播在线观看| 欧美日韩一区二区三区视视频| 精品人伦一区二区三区| 8x国产一区二区三区精品推荐| 日韩精品中文字幕一区二区三区| 91看片免费| 色婷婷av一区二区三区丝袜美腿| 在线播放亚洲精品| 欧美成人三级视频网站| 菠萝蜜一区二区| 天天影视涩香欲综合网| 99thz桃花论族在线播放| 男女高潮又爽又黄又无遮挡| 欧美色videos| 亚洲三级 欧美三级| 国产人妻精品久久久久野外| 苍井空张开腿实干12次| 久久er热在这里只有精品66| 亚洲欧美中日韩| 精品日产免费二区日产免费二区| 亚洲一区二区三区| 日韩欧美在线中字| 精品久久久久久久久久久久久久久| 免费看岛国视频在线观看| 久久99国内精品| 欧美日韩一区二区三区在线免费观看| 丁香视频五月| 国产亚洲一区在线播放| 免费视频一二三区| 欧美久久香蕉| 国产91色在线|免| 亚洲综合av影视| 狠狠色丁香婷婷综合| 国产伦理久久久| 福利片一区二区| 激情图片qvod| 欧美中日韩一区二区三区| 激情婷婷综合| 日韩欧美福利视频| 日本a级片免费观看| 91玉足脚交白嫩脚丫在线播放| 欧美性69xxxx肥| 天堂在线中文网官网| 精品成人无码一区二区三区| 9191国产精品| 无码播放一区二区三区| 国产黄色一级片| 国模私拍国内精品国内av| 亚洲av无码一区二区二三区| 中文字幕国产一区二区| 91嫩草亚洲精品| 九色精品美女在线| 日本精品一区二区三区不卡无字幕|