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


PHP Request::parseAccept方法代碼示例

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


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

示例1: prefers

 /**
  * Determines which content-types the client prefers. If no parameters are given,
  * the single content-type that the client most likely prefers is returned. If $type is
  * an array, the first item in the array that the client accepts is returned.
  * Preference is determined primarily by the file extension parsed by the Router
  * if provided, and secondarily by the list of content-types provided in
  * HTTP_ACCEPT.
  *
  * @param string|array $type An optional array of 'friendly' content-type names, i.e.
  *   'html', 'xml', 'js', etc.
  * @return mixed If $type is null or not provided, the first content-type in the
  *    list, based on preference, is returned. If a single type is provided
  *    a boolean will be returned if that type is preferred.
  *    If an array of types are provided then the first preferred type is returned.
  *    If no type is provided the first preferred type is returned.
  * @see RequestHandlerComponent::setContent()
  */
 public function prefers($type = null)
 {
     $acceptRaw = $this->request->parseAccept();
     if (empty($acceptRaw)) {
         return $this->ext;
     }
     $accepts = $this->response->mapType(array_shift($acceptRaw));
     if (!$type) {
         if (empty($this->ext) && !empty($accepts)) {
             return $accepts[0];
         }
         return $this->ext;
     }
     $types = (array) $type;
     if (count($types) === 1) {
         if (!empty($this->ext)) {
             return in_array($this->ext, $types);
         }
         return in_array($types[0], $accepts);
     }
     $intersect = array_values(array_intersect($accepts, $types));
     if (empty($intersect)) {
         return false;
     }
     return $intersect[0];
 }
開發者ID:ripzappa0924,項目名稱:carte0.0.1,代碼行數:43,代碼來源:RequestHandlerComponent.php

示例2: testParseAcceptInvalidSyntax

 /**
  * Test that parsing accept headers with invalid syntax works.
  *
  * The header used is missing a q value for application/xml.
  *
  * @return void
  */
 public function testParseAcceptInvalidSyntax()
 {
     $request = new Request(['environment' => ['url' => '/', 'HTTP_ACCEPT' => 'text/html,application/xhtml+xml,application/xml;image/png,image/jpeg,image/*;q=0.9,*/*;q=0.8']], false);
     $result = $request->parseAccept();
     $expected = ['1.0' => ['text/html', 'application/xhtml+xml', 'application/xml', 'image/jpeg'], '0.9' => ['image/*'], '0.8' => ['*/*']];
     $this->assertEquals($expected, $result);
 }
開發者ID:alexunique0519,項目名稱:Blog_Cakephp_association,代碼行數:14,代碼來源:RequestTest.php

示例3: _setExtension

 /**
  * Set the extension based on the accept headers.
  * Compares the accepted types and configured extensions.
  * If there is one common type, that is assigned as the ext/content type for the response.
  * The type with the highest weight will be set. If the highest weight has more
  * than one type matching the extensions, the order in which extensions are specified
  * determines which type will be set.
  *
  * If html is one of the preferred types, no content type will be set, this
  * is to avoid issues with browsers that prefer HTML and several other content types.
  *
  * @param \Cake\Network\Request $request The request instance.
  * @param \Cake\Network\Response $response The response instance.
  * @return void
  */
 protected function _setExtension($request, $response)
 {
     $accept = $request->parseAccept();
     if (empty($accept)) {
         return;
     }
     $accepts = $response->mapType($accept);
     $preferedTypes = current($accepts);
     if (array_intersect($preferedTypes, ['html', 'xhtml'])) {
         return;
     }
     $extensions = Router::extensions();
     foreach ($accepts as $types) {
         $ext = array_intersect($extensions, $types);
         if ($ext) {
             $this->ext = current($ext);
             break;
         }
     }
 }
開發者ID:KarimaLadhani,項目名稱:cakephp,代碼行數:35,代碼來源:RequestHandlerComponent.php

示例4: _setExtension

 /**
  * Set the extension based on the accept headers.
  * Compares the accepted types and configured extensions.
  * If there is one common type, that is assigned as the ext/content type for the response.
  * The type with the highest weight will be set. If the highest weight has more
  * than one type matching the extensions, the order in which extensions are specified
  * determines which type will be set.
  *
  * If html is one of the preferred types, no content type will be set, this
  * is to avoid issues with browsers that prefer HTML and several other content types.
  *
  * @param \Cake\Network\Request $request The request instance.
  * @param \Cake\Network\Response $response The response instance.
  * @return void
  */
 protected function _setExtension($request, $response)
 {
     $accept = $request->parseAccept();
     if (empty($accept)) {
         return;
     }
     $accepts = $response->mapType($accept);
     $preferredTypes = current($accepts);
     if (array_intersect($preferredTypes, ['html', 'xhtml'])) {
         return;
     }
     $extensions = array_unique(array_merge(Router::extensions(), array_keys($this->config('viewClassMap'))));
     foreach ($accepts as $types) {
         $ext = array_intersect($extensions, $types);
         if (!empty($ext)) {
             $this->ext = current($ext);
             break;
         }
     }
 }
開發者ID:malhan23,項目名稱:assignment-3,代碼行數:35,代碼來源:RequestHandlerComponent.php


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