Merge pull request #5 from sanderaido/master

Added option to define routes with multiple allowed methods
This commit is contained in:
SteamPixel 2019-02-25 16:25:37 +01:00 committed by GitHub
commit 7153d369c1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 34 additions and 12 deletions

View File

@ -6,6 +6,13 @@ class Route{
private static $pathNotFound = null; private static $pathNotFound = null;
private static $methodNotAllowed = null; private static $methodNotAllowed = null;
/**
* Function used to add a new route
* @param string $expression Route string or expression
* @param callable $function Function to call when route with allowed method is found
* @param string|array $method Either a string of allowed method or an array with string values
*
*/
public static function add($expression, $function, $method = 'get'){ public static function add($expression, $function, $method = 'get'){
array_push(self::$routes,Array( array_push(self::$routes,Array(
'expression' => $expression, 'expression' => $expression,
@ -66,8 +73,10 @@ class Route{
$path_match_found = true; $path_match_found = true;
// 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 // Check method match
if(strtolower($method) == strtolower($route['method'])){ 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
@ -84,6 +93,7 @@ class Route{
} }
} }
} }
}
// No matching route was found // No matching route was found
if(!$route_match_found){ if(!$route_match_found){

View File

@ -11,6 +11,7 @@ function navi () {
<li><a href="/foo/5/bar">foo 5 bar</a></li> <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="/foo/bar/foo/bar">long route example</a></li>
<li><a href="/contact-form">contact form</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="/test.html">test.html</a></li>
<li><a href="/aTrailingSlashDoesNotMatters">aTrailingSlashDoesNotMatters</a></li> <li><a href="/aTrailingSlashDoesNotMatters">aTrailingSlashDoesNotMatters</a></li>
<li><a href="/aTrailingSlashDoesNotMatters/">aTrailingSlashDoesNotMatters/</a></li> <li><a href="/aTrailingSlashDoesNotMatters/">aTrailingSlashDoesNotMatters/</a></li>
@ -56,6 +57,17 @@ Route::add('/contact-form',function(){
print_r($_POST); print_r($_POST);
},'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 // Route with regexp parameter
// Be aware that (.*) will match / (slash) too. For example: /user/foo/bar/edit // 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 (.*) // Also users could inject mysql-code or other untrusted data if you use (.*)