Added option to define routes with multiple allowed methods
This commit is contained in:
parent
d3f5e77ad3
commit
33c54c8511
23
Route.php
23
Route.php
|
@ -66,21 +66,24 @@ class Route{
|
|||
|
||||
$path_match_found = true;
|
||||
|
||||
// Check method match
|
||||
if(strtolower($method) == strtolower($route['method'])){
|
||||
// Cast allowed method to array if it's not one already, then run through all methods
|
||||
foreach ((array)$route['method'] as $allowedMethod) {
|
||||
// Check method match
|
||||
if(strtolower($method) == strtolower($allowedMethod)){
|
||||
|
||||
array_shift($matches);// Always remove first element. This contains the whole string
|
||||
array_shift($matches);// Always remove first element. This contains the whole string
|
||||
|
||||
if($basepath!=''&&$basepath!='/'){
|
||||
array_shift($matches);// Remove basepath
|
||||
}
|
||||
if($basepath!=''&&$basepath!='/'){
|
||||
array_shift($matches);// Remove basepath
|
||||
}
|
||||
|
||||
call_user_func_array($route['function'], $matches);
|
||||
call_user_func_array($route['function'], $matches);
|
||||
|
||||
$route_match_found = true;
|
||||
$route_match_found = true;
|
||||
|
||||
// Do not check other routes
|
||||
break;
|
||||
// Do not check other routes
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
16
index.php
16
index.php
|
@ -11,6 +11,7 @@ function navi () {
|
|||
<li><a href="/foo/5/bar">foo 5 bar</a></li>
|
||||
<li><a href="/foo/bar/foo/bar">long route example</a></li>
|
||||
<li><a href="/contact-form">contact form</a></li>
|
||||
<li><a href="/get-post-sample">get+post example</a></li>
|
||||
<li><a href="/test.html">test.html</a></li>
|
||||
<li><a href="/aTrailingSlashDoesNotMatters">aTrailingSlashDoesNotMatters</a></li>
|
||||
<li><a href="/aTrailingSlashDoesNotMatters/">aTrailingSlashDoesNotMatters/</a></li>
|
||||
|
@ -43,7 +44,7 @@ Route::add('/test.html',function(){
|
|||
echo 'Hello from test.html';
|
||||
});
|
||||
|
||||
// Post route example
|
||||
// Get route example
|
||||
Route::add('/contact-form',function(){
|
||||
navi();
|
||||
echo '<form method="post"><input type="text" name="test" /><input type="submit" value="send" /></form>';
|
||||
|
@ -56,6 +57,17 @@ Route::add('/contact-form',function(){
|
|||
print_r($_POST);
|
||||
},'post');
|
||||
|
||||
// Get and Post route example
|
||||
Route::add('/get-post-sample',function(){
|
||||
navi();
|
||||
echo 'You can GET this page and also POST this form back to it';
|
||||
echo '<form method="post"><input type="text" name="input" /><input type="submit" value="send" /></form>';
|
||||
if(isset($_POST["input"])){
|
||||
echo 'I also received a POST with this data:<br/>';
|
||||
print_r($_POST);
|
||||
}
|
||||
},['get','post']);
|
||||
|
||||
// Route with regexp parameter
|
||||
// Be aware that (.*) will match / (slash) too. For example: /user/foo/bar/edit
|
||||
// Also users could inject mysql-code or other untrusted data if you use (.*)
|
||||
|
@ -127,4 +139,4 @@ Route::run('/');
|
|||
// Enable case sensitive mode and trailing slashes by setting both to true
|
||||
// Route::run('/', true, true);
|
||||
|
||||
?>
|
||||
?>
|
||||
|
|
Loading…
Reference in New Issue
Block a user