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


PHP Request::is方法代碼示例

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


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

示例1: _secureRequired

 /**
  * Check if access requires secure connection
  *
  * @param \Cake\Controller\Controller $controller Instantiating controller
  * @return bool true if secure connection required
  */
 protected function _secureRequired(Controller $controller)
 {
     if (is_array($this->_config['requireSecure']) && !empty($this->_config['requireSecure'])) {
         $requireSecure = $this->_config['requireSecure'];
         if (in_array($this->_action, $requireSecure) || $requireSecure === ['*']) {
             if (!$this->request->is('ssl')) {
                 throw new SecurityException('Request is not SSL and the action is required to be secure');
             }
         }
     }
     return true;
 }
開發者ID:nrother,項目名稱:cakephp,代碼行數:18,代碼來源:SecurityComponent.php

示例2: _secureRequired

 /**
  * Check if access requires secure connection
  *
  * @param Controller $controller Instantiating controller
  * @return bool true if secure connection required
  */
 protected function _secureRequired(Controller $controller)
 {
     if (is_array($this->_config['requireSecure']) && !empty($this->_config['requireSecure'])) {
         $requireSecure = $this->_config['requireSecure'];
         if (in_array($this->_action, $requireSecure) || $requireSecure === ['*']) {
             if (!$this->request->is('ssl')) {
                 if (!$this->blackHole($controller, 'secure')) {
                     return null;
                 }
             }
         }
     }
     return true;
 }
開發者ID:yao-dev,項目名稱:blog-mvc.github.io,代碼行數:20,代碼來源:SecurityComponent.php

示例3: validate

 /**
  * {@inheritDoc}
  */
 public function validate(Request $request)
 {
     if ($request->is('post')) {
         // The (User's) Remote Address
         $whatRemoteIP = env('REMOTE_ADDR') ? '&remoteip=' . env('REMOTE_ADDR') : '';
         // The reCAPTCHA data is extracted from Request
         $gRecaptchaResponse = $request->data('g-recaptcha-response');
         // Verify reCAPTCHA data
         $response = file_get_contents('https://www.google.com/recaptcha/api/siteverify?secret=' . $this->config('secretKey') . '&response=' . $gRecaptchaResponse . $whatRemoteIP);
         $response = json_decode($response, true);
         // We return the Google server's response 'success' value
         return (bool) $response['success'];
     }
     return false;
 }
開發者ID:quickapps-plugins,項目名稱:captcha,代碼行數:18,代碼來源:RecaptchaAdapter.php

示例4: startup

 /**
  * The startup method of the RequestHandler enables several automatic behaviors
  * related to the detection of certain properties of the HTTP request, including:
  *
  * - If Router::extensions() is enabled, the layout and template type are
  *   switched based on the parsed extension or Accept-Type header. For example, if `controller/action.xml`
  *   is requested, the view path becomes `app/View/Controller/xml/action.ctp`. Also if
  *   `controller/action` is requested with `Accept-Type: application/xml` in the headers
  *   the view path will become `app/View/Controller/xml/action.ctp`. Layout and template
  *   types will only switch to mime-types recognized by Cake\Network\Response. If you need to declare
  *   additional mime-types, you can do so using Cake\Network\Response::type() in your controller's beforeFilter()
  *   method.
  * - If a helper with the same name as the extension exists, it is added to the controller.
  * - If the extension is of a type that RequestHandler understands, it will set that
  *   Content-type in the response header.
  * - If the XML data is POSTed, the data is parsed into an XML object, which is assigned
  *   to the $data property of the controller, which can then be saved to a model object.
  *
  * @param Event $event The startup event that was fired.
  * @return void
  */
 public function startup(Event $event)
 {
     $controller = $event->subject();
     $controller->request->params['isAjax'] = $this->request->is('ajax');
     $isRecognized = !in_array($this->ext, ['html', 'htm']) && $this->response->getMimeType($this->ext);
     if (!empty($this->ext) && $isRecognized) {
         $this->renderAs($controller, $this->ext);
     } elseif (empty($this->ext) || in_array($this->ext, ['html', 'htm'])) {
         $this->respondAs('html', ['charset' => Configure::read('App.encoding')]);
     }
     foreach ($this->_inputTypeMap as $type => $handler) {
         if ($this->requestedWith($type)) {
             $input = call_user_func_array([$controller->request, 'input'], $handler);
             $controller->request->data = $input;
         }
     }
 }
開發者ID:ansidev,項目名稱:cakephp_blog,代碼行數:38,代碼來源:RequestHandlerComponent.php

示例5: authorize

 /**
  * Authorizes current logged in user, if user belongs to the "administrator"
  * he/she is automatically authorized.
  *
  * @param array $user Active user data
  * @param \Cake\Network\Request $request Request instance
  * @return bool True if user is can access this request
  */
 public function authorize($user, Request $request)
 {
     if ($request->is('userAdmin')) {
         return true;
     }
     $user = user();
     $path = $this->requestPath($request);
     $cacheKey = 'permissions_' . intval($user->id);
     $permissions = Cache::read($cacheKey, 'permissions');
     if ($permissions === false) {
         $permissions = [];
         Cache::write($cacheKey, [], 'permissions');
     }
     if (!isset($permissions[$path])) {
         $allowed = $user->isAllowed($path);
         $permissions[$path] = $allowed;
         Cache::write($cacheKey, $permissions, 'permissions');
     } else {
         $allowed = $permissions[$path];
     }
     return $allowed;
 }
開發者ID:quickapps-plugins,項目名稱:user,代碼行數:30,代碼來源:CachedAuthorize.php

示例6: requestedWith

 /**
  * Determines the content type of the data the client has sent (i.e. in a POST request)
  *
  * @param string|array $type Can be null (or no parameter), a string type name, or an array of types
  * @return mixed If a single type is supplied a boolean will be returned. If no type is provided
  *   The mapped value of CONTENT_TYPE will be returned. If an array is supplied the first type
  *   in the request content type will be returned.
  */
 public function requestedWith($type = null)
 {
     if (!$this->request->is('post') && !$this->request->is('put')) {
         return null;
     }
     if (is_array($type)) {
         foreach ($type as $t) {
             if ($this->requestedWith($t)) {
                 return $t;
             }
         }
         return false;
     }
     list($contentType) = explode(';', $this->request->env('CONTENT_TYPE'));
     if ($contentType === '') {
         list($contentType) = explode(';', $this->request->header('CONTENT_TYPE'));
     }
     if (!$type) {
         return $this->response->mapType($contentType);
     }
     if (is_string($type)) {
         return $type === $this->response->mapType($contentType);
     }
 }
開發者ID:ripzappa0924,項目名稱:carte0.0.1,代碼行數:32,代碼來源:RequestHandlerComponent.php

示例7: cors

 /**
  * Setup access for origin and methods on cross origin requests
  *
  * This method allow multiple ways to setup the domains, see the examples
  *
  * ### Full URI
  * ```
  * cors($request, 'http://www.cakephp.org');
  * ```
  *
  * ### URI with wildcard
  * ```
  * cors($request, 'http://*.cakephp.org');
  * ```
  *
  * ### Ignoring the requested protocol
  * ```
  * cors($request, 'www.cakephp.org');
  * ```
  *
  * ### Any URI
  * ```
  * cors($request, '*');
  * ```
  *
  * ### Whitelist of URIs
  * ```
  * cors($request, ['http://www.cakephp.org', '*.google.com', 'https://myproject.github.io']);
  * ```
  *
  * @param \Cake\Network\Request $request Request object
  * @param string|array $allowedDomains List of allowed domains, see method description for more details
  * @param string|array $allowedMethods List of HTTP verbs allowed
  * @param string|array $allowedHeaders List of HTTP headers allowed
  * @return void
  */
 public function cors(Request $request, $allowedDomains, $allowedMethods = [], $allowedHeaders = [])
 {
     $origin = $request->header('Origin');
     if (!$origin) {
         return;
     }
     $allowedDomains = $this->_normalizeCorsDomains((array) $allowedDomains, $request->is('ssl'));
     foreach ($allowedDomains as $domain) {
         if (!preg_match($domain['preg'], $origin)) {
             continue;
         }
         $this->header('Access-Control-Allow-Origin', $domain['original'] === '*' ? '*' : $origin);
         $allowedMethods && $this->header('Access-Control-Allow-Methods', implode(', ', (array) $allowedMethods));
         $allowedHeaders && $this->header('Access-Control-Allow-Headers', implode(', ', (array) $allowedHeaders));
         break;
     }
 }
開發者ID:rabinpal,項目名稱:cakephp,代碼行數:53,代碼來源:Response.php

示例8: testIsRequested

 /**
  * Test is('requested') and isRequested()
  *
  * @return void
  */
 public function testIsRequested()
 {
     $request = new Request();
     $request->addParams(['controller' => 'posts', 'action' => 'index', 'plugin' => null, 'requested' => 1]);
     $this->assertTrue($request->is('requested'));
     $this->assertTrue($request->isRequested());
     $request = new Request();
     $request->addParams(['controller' => 'posts', 'action' => 'index', 'plugin' => null]);
     $this->assertFalse($request->is('requested'));
     $this->assertFalse($request->isRequested());
 }
開發者ID:alexunique0519,項目名稱:Blog_Cakephp_association,代碼行數:16,代碼來源:RequestTest.php

示例9: cors

 /**
  * Setup access for origin and methods on cross origin requests
  *
  * This method allow multiple ways to setup the domains, see the examples
  *
  * ### Full URI
  * ```
  * cors($request, 'http://www.cakephp.org');
  * ```
  *
  * ### URI with wildcard
  * ```
  * cors($request, 'http://*.cakephp.org');
  * ```
  *
  * ### Ignoring the requested protocol
  * ```
  * cors($request, 'www.cakephp.org');
  * ```
  *
  * ### Any URI
  * ```
  * cors($request, '*');
  * ```
  *
  * ### Whitelist of URIs
  * ```
  * cors($request, ['http://www.cakephp.org', '*.google.com', 'https://myproject.github.io']);
  * ```
  *
  * *Note* The `$allowedDomains`, `$allowedMethods`, `$allowedHeaders` parameters are deprecated.
  * Instead the builder object should be used.
  *
  * @param \Cake\Network\Request $request Request object
  * @param string|array $allowedDomains List of allowed domains, see method description for more details
  * @param string|array $allowedMethods List of HTTP verbs allowed
  * @param string|array $allowedHeaders List of HTTP headers allowed
  * @return \Cake\Network\CorsBuilder A builder object the provides a fluent interface for defining
  *   additional CORS headers.
  */
 public function cors(Request $request, $allowedDomains = [], $allowedMethods = [], $allowedHeaders = [])
 {
     $origin = $request->header('Origin');
     $ssl = $request->is('ssl');
     $builder = new CorsBuilder($this, $origin, $ssl);
     if (!$origin) {
         return $builder;
     }
     if (empty($allowedDomains) && empty($allowedMethods) && empty($allowedHeaders)) {
         return $builder;
     }
     $builder->allowOrigin($allowedDomains)->allowMethods((array) $allowedMethods)->allowHeaders((array) $allowedHeaders)->build();
     return $builder;
 }
開發者ID:CakeDC,項目名稱:cakephp,代碼行數:54,代碼來源:Response.php

示例10: function

 * to set as the default:
 *
 * - Route
 * - InflectedRoute
 * - DashedRoute
 *
 * If no call is made to `Router::defaultRouteClass()`, the class used is
 * `Route` (`Cake\Routing\Route\Route`)
 *
 * Note that `Route` does not do any inflections on URLs which will result in
 * inconsistently cased URLs when used with `:plugin`, `:controller` and
 * `:action` markers.
 *
 */
$req = new Network\Request();
if ($req->is('get')) {
    Router::defaultRouteClass('DashedRoute');
    Router::scope('/', function ($routes) {
        $routes->connect('demo', ['controller' => 'User', 'action' => 'show', 'show']);
        $routes->connect('demo/activation', ['controller' => 'User', 'action' => 'activation']);
        //  $routes->connect('demo', ['controller' => 'Demo', 'action' => 'display', 'display']);
        $routes->fallbacks('DashedRoute');
    });
} elseif ($req->is('Post')) {
    Router::defaultRouteClass('DashedRoute');
    Router::scope('/', function ($routes) {
        $routes->connect('demo', ['controller' => 'User', 'action' => 'show', 'show']);
        $routes->connect('demo/activation', ['controller' => 'User', 'action' => 'activation']);
        //  $routes->connect('demo', ['controller' => 'Demo', 'action' => 'display', 'display']);
        $routes->fallbacks('DashedRoute');
    });
開發者ID:Vniteen,項目名稱:MobileTravelApp,代碼行數:31,代碼來源:routes.php

示例11: getFilterQuery

 /**
  * $options:
  * ---------
  * 'check_referer'              indicates wether eventual existing filter for the current url must be reused only if the referer is the same url
  *                              true by default -> filter is preserved only during pagination navigation
  *                              
  * 'auto_wildcard_string'       true by default -> automatcally appends wildcard character '%' around search terms
  * 
  * @param array $options
  * @return \Cake\ORM\Query
  */
 public function getFilterQuery(array $options = array())
 {
     $default_options = ['check_referer' => true, 'keep_filter_actions' => ['add', 'copy', 'edit', 'view', 'delete'], 'auto_wildcard_string' => true];
     $options = array_merge($default_options, $options);
     /*
      * Prepare Entity used to display search filters in the view
      */
     $this->prepareSearchEntity($options);
     $options['modelClass'] = isset($options['modelClass']) ? $options['modelClass'] : $this->controller->modelClass;
     /******/
     $filter_data = null;
     if ($this->request->is('post') || $this->request->is('put')) {
         if (isset($this->request->data['Filter']) && !empty($this->request->data['Filter'])) {
             $filter_data = $this->request->data['Filter'];
         }
     } elseif ($this->request->is('get')) {
         $current_path = $this->getComparisonPath($this->request->params);
         if ($options['check_referer']) {
             if ($this->filterMustBeCleared($options)) {
                 $this->clearStoredQuery($current_path);
             } else {
                 $filter_data = $this->getStoredQuery($current_path, $options);
             }
         } else {
             $filter_data = $this->getStoredQuery($current_path, $options);
         }
     }
     /******/
     $query = $this->controller->{$options['modelClass']}->find();
     if (isset($options['contain'])) {
         $query->contain($options['contain']);
     }
     /******/
     if (!empty($filter_data)) {
         /*
          * Normalize $filter_data to get a flat array, even if some filters concern linked models 
          */
         $flat_filter_data = [];
         foreach ($filter_data as $fieldName => $value) {
             if (!is_array($value) || isset($value['__start__']) || isset($value['__end__'])) {
                 /*
                  * Conditions on main model
                  */
                 $flat_filter_data[$options['modelClass']] = isset($flat_filter_data[$options['modelClass']]) ? $flat_filter_data[$options['modelClass']] : array();
                 $flat_filter_data[$options['modelClass']][$fieldName] = $value;
             } else {
                 /*
                  * Conditions on linked model
                  */
                 $flat_filter_data[$options['modelClass'] . '.' . $fieldName] = isset($flat_filter_data[$options['modelClass'] . '.' . $fieldName]) ? $flat_filter_data[$options['modelClass'] . '.' . $fieldName] : array();
                 foreach ($value as $linked_model_fieldname => $linked_value) {
                     if (!is_array($linked_value) || isset($linked_value['__start__']) || isset($linked_value['__end__'])) {
                         /*
                          * Case of LinkedModels.title
                          */
                         $flat_filter_data[$options['modelClass'] . '.' . $fieldName][$linked_model_fieldname] = $linked_value;
                     } else {
                         $flat_filter_data[$options['modelClass'] . '.' . $fieldName . '.' . $linked_model_fieldname] = isset($flat_filter_data[$options['modelClass'] . '.' . $fieldName . '.' . $linked_model_fieldname]) ? $flat_filter_data[$options['modelClass'] . '.' . $fieldName . '.' . $linked_model_fieldname] : array();
                         foreach ($linked_value as $linked_model_2_fieldname => $linked_value_2) {
                             if (!is_array($linked_value_2) || isset($linked_value_2['__start__']) || isset($linked_value_2['__end__'])) {
                                 /*
                                  * Case of LinkedModels.LinkedModels.title
                                  */
                                 $flat_filter_data[$options['modelClass'] . '.' . $fieldName . '.' . $linked_model_fieldname][$linked_model_2_fieldname] = $linked_value_2;
                             } else {
                                 throw new NotImplementedException(___('filtering on 3rd level related model is not implemented'));
                             }
                         }
                     }
                 }
             }
         }
         /******/
         foreach ($flat_filter_data as $modelName => $conditions) {
             foreach ($conditions as $fieldName => $value) {
                 $has_value = false;
                 if (!is_array($value)) {
                     if (!empty($value) || $value === '0') {
                         $has_value = true;
                     }
                 } else {
                     /*
                      * Case of From - To
                      */
                     if (isset($value['__start__']) && (!empty($value['__start__']) || $value['__start__'] === '0')) {
                         $has_value = true;
                     }
                     if (isset($value['__end__']) && (!empty($value['__end__']) || $value['__end__'] === '0')) {
                         $has_value = true;
//.........這裏部分代碼省略.........
開發者ID:alaxos,項目名稱:cakephp3-libs,代碼行數:101,代碼來源:FilterComponent.php


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