PHP micro-router (MIT Licensed)
Route66 was written to add some features to the minimalist Macaw router without bloating it.
server {
index index.html index.htm index.php;
location / {
try_files $uri $uri/ /index.php?/$uri;
}
location ~ \.php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
}
require 'Route66.php';
https://packagist.org/packages/leeoniya/route66
{
"require": {
"leeoniya/route66": "dev-master"
}
}
// front controller (index.php)
require 'Route66.php';
use Route66 as R;
R::get('/', function() {
echo 'Hello world!';
});
R::dispatch();
// any HTTP method can be bound via static invocation using its name
R::post('/topics', function() {});
// multiple methods
R::match('post|put', '/comment', function() {});
// equivalent to R::match('get|post|put|patch|delete|head|options',..)
R::any('/', function() {};)
// basic param (all characters except '/')
R::get('/posts/@id', function($id) {});
// param validated by regex alias
R::get('/posts/@id:alpha', function($id) {});
// aliases and regexs can be broken out for readability
R::get('/posts/@id', function($id) {}, ['id' => ':alpha']);
R::get('/posts/@id', function($id) {}, ['id' => '\w{12}']);
// define a custom alias
R::alias(':date', '[0-9]{4}-[0-9]{2}-[0-9]{2}');
// optional params with defaults (set in handler)
R::get('/posts(/@year(/@month(/@day)))', function($year = 2015, $month = 6, $day = 15) {});
// regex alias without a param (non-capturing)
R::get('/posts(/:slug)', function() {});
// optional trailing slash (though rtrim-ing it from REQUEST_URI before dispatch is faster)
R::get('/blog/?', function() {});
// un-named params via regex capture groups
R::get('/posts/(\w{12})', function($id) {});
R::base('/blog');
R::get('/posts', function() {}); // maps to /blog/posts
R::base('/admin');
R::get('/login', function() {}); // maps to /admin/login
// before all /admin* routes
R::get('/admin(/:all)', function() {
// verify valid session, etc...
return R::NOHALT; // fall through to additional routes
});
R::get('/admin/dashboard', function() {
// show dashboard...
});
R::nomatch(function($meth, $uri) {
header($_SERVER["SERVER_PROTOCOL"] . " 404 Not Found");
exit('404 Not Found.');
});
R::dispatch('get', '/blog');
// example of storing compiled routes in session
session_start();
if ($routes = @$_SESSION['routes'])
R::import($routes);
// define all routes here
R::dispatch();
if (!isset($_SESSION['routes']))
$_SESSION['routes'] = R::export();
// un-named
R::get('/users/@id', function($id) {}, ['id'=>':alpha']);
// named (the trailing 2 args can be passed in any order. all below are equivalent.)
R::get('/users/@id', function($id) {}, 'named1');
R::get('/users/@id', function($id) {}, ['id'=>':alpha'], 'named1');
R::get('/users/@id', function($id) {}, 'named1', ['id'=>':alpha']);
// dispatch a named route
R::dispatch('get', 'named1', ['id' => 'abc123']);
R::is_ajax();
R::is_https();
R::redirect($location, $code = 301);
@user:alpha
)is_ajax
, is_https
and redirect
* As with any router, speed will depend on: route quantity & complexity, numbers of params, whether caching is used, server hardware, PHP version, opcode caching.