本文整理匯總了PHP中Illuminate\Routing\Route::matches方法的典型用法代碼示例。如果您正苦於以下問題:PHP Route::matches方法的具體用法?PHP Route::matches怎麽用?PHP Route::matches使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Illuminate\Routing\Route
的用法示例。
在下文中一共展示了Route::matches方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: setRoute
/**
* @param RouteInstance $route
*/
public function setRoute(RouteInstance $route)
{
// Compile route
$request = new Request();
$route->matches($request);
$this->route = $route;
}
示例2: validateSignedURL
public function validateSignedURL($actual_url, $signed_url, $substitions)
{
$current_route = Request::route();
$current_route_name = $current_route->getName();
if (isset($substitions[$current_route_name])) {
$substition = $substitions[$current_route_name];
// make sure the host of the signed URL matches the host of the substitution URL
if (isset($substition['host'])) {
$signed_host = $this->getHostFromURL($signed_url);
$allowed_host = $substition['host'];
if ($signed_host != $allowed_host) {
Log::debug("HOST MISMATCH: \$signed_host={$signed_host} \$allowed_host={$allowed_host}");
// no host match - return false
return false;
}
}
// check the route
$substitute_route = new Route($current_route->getMethods(), $substition['route'], []);
$signed_request = \Illuminate\Http\Request::create($signed_url, Request::method());
if ($substitute_route->matches($signed_request)) {
// the allowed substitute route matches the signed request
return true;
}
Log::debug("ROUTE MISMATCH: pathinfo=" . json_encode(Request::getFacadeRoot()->getPathInfo()) . " allowed route={$substition['route']}");
}
// this signed URL was not valid
return false;
}
示例3: matches
/**
* Determine if the route matches given request.
*
* @param \Illuminate\Http\Request $request
* @param bool $includingMethod
*
* @return bool
*/
public function matches(Request $request, $includingMethod = true)
{
// If this route uses a WordPress conditional tag
if ($this->condition()) {
// Loop trough every validator and if the route passes, return true else false.
foreach ($this->getWpValidators() as $validator) {
return $validator->matches($this, $request);
}
return false;
}
// If no WordPress condition is found, use the normal way of getting a route
$matches = parent::matches($request, $includingMethod);
// If we can not find a route using the normal laravel router check if the route which is being checked has the uri "404". If so we return this route as the valid one.
return !$matches && $this->getUri() === '404' ? true : $matches;
}