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


PHP Request::is方法代碼示例

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


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

示例1: handle

 /**
  * Handle an incoming request.
  *
  * @param  \Illuminate\Http\Request  $request
  * @param  \Closure  $next
  * @return mixed
  */
 public function handle($request, Closure $next)
 {
     if (!$request->is('install') && !$request->is('install/*') && !Storage::exists('public/install.lock')) {
         return redirect('/install');
     }
     return $next($request);
 }
開發者ID:koyeo,項目名稱:bichon,代碼行數:14,代碼來源:InstallCheck.php

示例2: handle

 /**
  * Handle an incoming request.
  *
  * @param  \Illuminate\Http\Request  $request
  * @param  \Closure  $next
  * @return mixed
  */
 public function handle($request, Closure $next)
 {
     $loggingIn = $request->is('api/v1/login') || $request->is('api/v1/register') || $request->is('api/v1/oauth_login');
     $headers = Utils::getApiHeaders();
     $hasApiSecret = false;
     if ($secret = env(API_SECRET)) {
         $requestSecret = Request::header('X-Ninja-Secret') ?: ($request->api_secret ?: '');
         $hasApiSecret = hash_equals($requestSecret, $secret);
     }
     if ($loggingIn) {
         // check API secret
         if (!$hasApiSecret) {
             sleep(ERROR_DELAY);
             return Response::json('Invalid value for API_SECRET', 403, $headers);
         }
     } else {
         // check for a valid token
         $token = AccountToken::where('token', '=', Request::header('X-Ninja-Token'))->first(['id', 'user_id']);
         // check if user is archived
         if ($token && $token->user) {
             Auth::onceUsingId($token->user_id);
             Session::set('token_id', $token->id);
         } else {
             sleep(ERROR_DELAY);
             return Response::json('Invalid token', 403, $headers);
         }
     }
     if (!Utils::isNinja() && !$loggingIn) {
         return $next($request);
     }
     if (!Utils::hasFeature(FEATURE_API) && !$hasApiSecret) {
         return Response::json('API requires pro plan', 403, $headers);
     } else {
         $key = Auth::check() ? Auth::user()->account->id : $request->getClientIp();
         // http://stackoverflow.com/questions/1375501/how-do-i-throttle-my-sites-api-users
         $hour = 60 * 60;
         $hour_limit = 100;
         # users are limited to 100 requests/hour
         $hour_throttle = Cache::get("hour_throttle:{$key}", null);
         $last_api_request = Cache::get("last_api_request:{$key}", 0);
         $last_api_diff = time() - $last_api_request;
         if (is_null($hour_throttle)) {
             $new_hour_throttle = 0;
         } else {
             $new_hour_throttle = $hour_throttle - $last_api_diff;
             $new_hour_throttle = $new_hour_throttle < 0 ? 0 : $new_hour_throttle;
             $new_hour_throttle += $hour / $hour_limit;
             $hour_hits_remaining = floor(($hour - $new_hour_throttle) * $hour_limit / $hour);
             $hour_hits_remaining = $hour_hits_remaining >= 0 ? $hour_hits_remaining : 0;
         }
         if ($new_hour_throttle > $hour) {
             $wait = ceil($new_hour_throttle - $hour);
             sleep(1);
             return Response::json("Please wait {$wait} second(s)", 403, $headers);
         }
         Cache::put("hour_throttle:{$key}", $new_hour_throttle, 10);
         Cache::put("last_api_request:{$key}", time(), 10);
     }
     return $next($request);
 }
開發者ID:hillelcoren,項目名稱:invoice-ninja,代碼行數:67,代碼來源:ApiCheck.php

示例3: handle

 /**
  * Handle an incoming request.
  *
  * @param  \Illuminate\Http\Request $request
  * @param  \Closure                 $next
  *
  * @return mixed
  */
 public function handle($request, Closure $next)
 {
     if ($request->isMethod('get') && !$request->has('PageSpeed') && !$request->is(config('site.admin_path') . '*') && !$request->is('avatar/*') && !$request->is('my/*') && !$request->is('*/login') && !$request->is('*/authorize') && !in_array($request->path(), ['sitemap.xml', 'logout', 'login'])) {
         $aSiteMap = Cache::get('sitemap', []);
         $changefreq = 'always';
         if (!empty($aSiteMap[$request->fullUrl()]['added'])) {
             $aDateDiff = Carbon::createFromTimestamp($aSiteMap[$request->fullUrl()]['added'])->diff(Carbon::now());
             if ($aDateDiff->y > 0) {
                 $changefreq = 'yearly';
             } else {
                 if ($aDateDiff->m > 0) {
                     $changefreq = 'monthly';
                 } else {
                     if ($aDateDiff->d > 6) {
                         $changefreq = 'weekly';
                     } else {
                         if ($aDateDiff->d > 0 && $aDateDiff->d < 7) {
                             $changefreq = 'daily';
                         } else {
                             if ($aDateDiff->h > 0) {
                                 $changefreq = 'hourly';
                             } else {
                                 $changefreq = 'always';
                             }
                         }
                     }
                 }
             }
         }
         $aSiteMap[$request->fullUrl()] = ['added' => time(), 'lastmod' => Carbon::now()->format('Y-m-d\\TH:i:sP'), 'priority' => 1 - substr_count($request->getPathInfo(), '/') / 10, 'changefreq' => $changefreq];
         Cache::forever('sitemap', $aSiteMap);
     }
     return $next($request);
 }
開發者ID:vnsource,項目名稱:core,代碼行數:42,代碼來源:Sitemap.php

示例4: handle

 /**
  * Handle an incoming request.
  *
  * @param  \Illuminate\Http\Request  $request
  * @param  \Closure  $next
  * @return mixed
  */
 public function handle($request, Closure $next)
 {
     $rota = Request::segment(1);
     if ($rota == 'auth' && Auth::guest()) {
         return redirect('/auth/login');
     }
     print time();
     dd('rrr');
     //dd($rota);
     if ($request->is('auth')) {
         dd('ddd');
         return redirect('/auth/login');
     }
     if (!$request->is('/auth/login') && Auth::guest()) {
         //    dd('oi');
         return redirect('/auth/login');
     }
     print $rota;
     if (($rota == null || $rota == 'auth' || $rota == 'home' || $request->is('permissao/negada')) && Auth::guest()) {
         return $next($request);
     }
     //dd( $request->is('Auth/logout') );
     $url = Request::url();
     print_r($url);
     //dd();
     if (!Infra_Permissao::tem_permissao()) {
         //die( 'NÂO tem permssao - redirecionar para uma view sem permissao');
         print time();
         //dd();
         return redirect('permissao/negada');
     }
     return $next($request);
 }
開發者ID:alipusman,項目名稱:laravel5,代碼行數:40,代碼來源:PermissaoMiddleware.php

示例5: handle

 /**
  * Handle an incoming request.
  *
  * @param  \Illuminate\Http\Request  $request
  * @param  \Closure  $next
  * @return mixed
  */
 public function handle($request, Closure $next)
 {
     /**
      * check for ban by ip
      */
     $remote_ip = $request->ip();
     $cache_key = '_ban_ip_' . $remote_ip;
     $ban_info = Cache::rememberForever($cache_key, function () use($remote_ip) {
         return AdBanIp::where('ban_ip', $remote_ip)->first();
     });
     if (!empty($ban_info) && !$request->is('ban')) {
         return redirect('ban');
     }
     /**
      * check if user is banned my email
      */
     if (Auth()->check()) {
         $user_mail = Auth()->user()->email;
         $cache_key = '_ban_email_' . $user_mail;
         $ban_info = Cache::rememberForever($cache_key, function () use($user_mail) {
             return AdBanEmail::where('ban_email', $user_mail)->first();
         });
         if (!empty($ban_info) && !$request->is('ban')) {
             return redirect('ban');
         }
     }
     return $next($request);
 }
開發者ID:gdinko,項目名稱:dclassifieds.laravel,代碼行數:35,代碼來源:BanMiddleware.php

示例6: handle

 /**
  * Handle an incoming request.
  *
  * @param  \Illuminate\Http\Request  $request
  * @param  \Closure  $next
  * @return mixed
  */
 public function handle($request, Closure $next)
 {
     if ($request->is('administrator/*') || $request->is('administrator')) {
         config()->set('auth.defaults.guard', 'administrator');
     }
     return $next($request);
 }
開發者ID:yajra,項目名稱:cms-core,代碼行數:14,代碼來源:AdministratorUserResolver.php

示例7: handle

 /**
  * Handle an incoming request.
  *
  * @param  \Illuminate\Http\Request  $request
  * @param  \Closure  $next
  * @return mixed
  */
 public function handle($request, Closure $next)
 {
     if (!$request->is('auth/*') && !$request->is('api/*') && $this->auth->guest()) {
         return redirect()->guest('auth/login');
     }
     return $next($request);
 }
開發者ID:nathan-lochala,項目名稱:SF,代碼行數:14,代碼來源:AuthenticateAllPages.php

示例8: handle

 /**
  * Handle an incoming request.
  *
  * @param  \Illuminate\Http\Request  $request
  * @param  \Closure  $next
  * @return mixed
  */
 public function handle($request, Closure $next)
 {
     if ($this->auth->guest()) {
         if ($request->ajax()) {
             return response('Unauthorized.', 401);
         } else {
             //                return redirect()->guest('auth/login');
             return redirect()->guest('dangnhap');
         }
     }
     if ($request->is('giangvien/*')) {
         if (\Auth::user()->quyen != 'gv') {
             return redirect()->guest('dangnhap');
         }
     }
     if ($request->is('quantri/*')) {
         if (\Auth::user()->quyen != 'qt') {
             return redirect()->guest('dangnhap');
         }
     }
     if ($request->is('sinhvien/*')) {
         if (\Auth::user()->quyen != 'sv') {
             return redirect()->guest('dangnhap');
         }
     }
     /* $action = $request->route()->getActionName();
        echo $action; */
     return $next($request);
 }
開發者ID:HaNguyen1410,項目名稱:laravProject1,代碼行數:36,代碼來源:Authenticate.php

示例9: Response

 public function Response(Request $request, $id)
 {
     $uri = $request->path();
     $method = $request->method();
     if ($request->is('countries')) {
         if ($request->has('filter')) {
             $zones = CountryAdapter::zoneByName($request->filter);
         } else {
             $zones = CountryAdapter::zones();
         }
         return $this->apiOutput(function () use($zones) {
             $data = array();
             foreach ($zones as $i => $zone) {
                 $tmp_data[$i] = ['zone' => $zone->name, 'countries' => CountryAdapter::getByZone($zone)];
                 array_push($data, $tmp_data[$i]);
             }
             return $data;
         });
     } elseif ($request->is('countries/*')) {
         $country = CountryAdapter::getById($id);
         return $this->apiOutput(function () use($country) {
             $zone = CountryAdapter::zoneById($country->zone_id);
             $country_data = ['id' => intval($country->numeric_code), 'name' => $country->name, 'zone' => $zone->name, 'alpha2' => $country->alpha2, 'alpha3' => $country->alpha3];
             return $country_data;
         });
     } else {
         dd('error');
     }
 }
開發者ID:jnaxo,項目名稱:country-codes,代碼行數:29,代碼來源:CountryStore.php

示例10: handle

 /**
  * Handle an incoming request.
  *
  * @param  \Illuminate\Http\Request  $request
  * @param  \Closure  $next
  * @return mixed
  */
 public function handle($request, Closure $next)
 {
     if (!Auth::check()) {
         if (!($request->is('auth/login') or $request->is('auth/register'))) {
             return redirect('/auth/login');
         }
     }
     return $next($request);
 }
開發者ID:michael-dean-haynie,項目名稱:my-secret-santa,代碼行數:16,代碼來源:LoggedInMiddleware.php

示例11: handle

 /**
  * Handle an incoming request.
  *
  * @param  \Illuminate\Http\Request  $request
  * @param  \Closure  $next
  * @return mixed
  */
 public function handle($request, Closure $next)
 {
     if (!$request->session()->has('user') && (!$request->is('user/*') || $request->is('user/logout'))) {
         return redirect('user/login');
     } elseif ($request->session()->has('user') && ($request->is('user/*') && !$request->is('user/logout'))) {
         return redirect('/');
     }
     return $next($request);
 }
開發者ID:pratyush20,項目名稱:lara_drupal,代碼行數:16,代碼來源:Custom.php

示例12: compose

 /**
  * compose.
  *
  * @param View $view 視圖對象
  */
 public function compose(View $view)
 {
     $menus = $this->request->is('admin/account*') ? config('menu.account') : config('menu.func');
     $global = new Fluent();
     $global->user = Auth::user();
     $global->menus = $menus;
     $global->current_account = app('viease.current_account');
     $global->accounts = $this->accountRepository->lists(99);
     $view->with('global', $global);
 }
開發者ID:renyang9876,項目名稱:viease,代碼行數:15,代碼來源:AdminComposer.php

示例13: handle

 /**
  * This middleware forces power users to use TFA before they can do anything else.
  *
  * @param  \Illuminate\Http\Request $request
  * @param  \Closure $next
  * @return mixed
  */
 public function handle($request, Closure $next)
 {
     if (App::environment('production') && Auth::check() && Auth::user()->hasRole(config('proto.tfaroles')) && (!Auth::user()->tfa_totp_key && !Auth::user()->tfa_yubikey_identity)) {
         if (!$request->is('user/dashboard') && !$request->is('auth/logout') && !$request->is('user/quit_impersonating') && !$request->is('user/*/2fa/*')) {
             $request->session()->flash('flash_message', 'Since you are able to access a lot of sensitive information, you are required to enable Two Factor Authentication on your account. Please do so now! :)');
             return Redirect::route('user::dashboard');
         }
     }
     return $next($request);
 }
開發者ID:saproto,項目名稱:saproto,代碼行數:17,代碼來源:EnforceTFA.php

示例14: handle

 public function handle(Request $request, Closure $next)
 {
     if (!$request->is('account/verify') && !$request->is('account/reissue-code') && !$request->is('users/logout') && $this->requiresVerification($request)) {
         $verification = new UserVerification($this->auth->user(), $request);
         if (!$verification->isDone()) {
             return $verification->initiate();
         }
     }
     return $next($request);
 }
開發者ID:ppy,項目名稱:osu-web,代碼行數:10,代碼來源:VerifyUser.php

示例15: handle

 /**
  * Handle an incoming request.
  *
  * @param \Illuminate\Http\Request $request
  * @param \Closure $next
  *
  * @param string|null $context
  *
  * @return mixed
  */
 public function handle($request, Closure $next, $context = null)
 {
     if (is_null($context)) {
         $context = ($request->is(backend_url_segment()) or $request->is(backend_url_segment() . '/*')) ? \KodiCMS\CMS\CMS::CONTEXT_BACKEND : \KodiCMS\CMS\CMS::CONTEXT_FRONTEND;
     }
     $contexts = explode('|', $context);
     foreach ($contexts as $context) {
         CMS::setContext($context);
     }
     return $next($request);
 }
開發者ID:KodiComponents,項目名稱:module-core,代碼行數:21,代碼來源:Context.php


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