Wallogit.com
2017 © Pedro Peláez
Simple PHP router class.
Macaw is a simple, open source PHP router. It's super small (~150 LOC), fast, and has some great annotated source code. This class allows you to just throw it into your project and start using it immediately., (*1)
If you have Composer, just include Macaw as a project dependency in your composer.json. If you don't just install it by downloading the .ZIP file and extracting it to your project directory., (*2)
require: {
"marcfowler/macaw": "dev-master"
}
First, use the Macaw namespace:, (*3)
use \marcfowler\macaw\Macaw;
Macaw is not an object, so you can just make direct operations to the class. Here's the Hello World:, (*4)
Macaw::get('/', function() {
echo 'Hello world!';
});
Macaw::dispatch();
You can specify a prefix which will be added to all of your routes. This is useful to prevent duplication if you know you're running behind a particular URL that isn't always defined by the directory you're executing from. For example, if you know your file is accessed at /subfolder/somewhere-else/, you can:, (*5)
Macaw::setPrefix('/subfolder/somewhere-else/');
Macaw::get('/', function() {
echo 'Hello!';
});
Macaw also supports lambda URIs, such as:, (*6)
Macaw::get('/(:any)', function($slug) {
echo 'The slug is: ' . $slug;
});
Macaw::dispatch();
You can also make requests for HTTP methods in Macaw, so you could also do:, (*7)
Macaw::get('/', function() {
echo 'I <3 GET commands!';
});
Macaw::post('/', function() {
echo 'I <3 POST commands!';
});
Macaw::dispatch();
You may want to stop execution once a matching route is found. Without the call to haltOnMatch() below, if you requested /, you would see both 'Hello world!' and 'I am further execution...' displayed. To prevent that, simply add the line:, (*8)
Macaw::haltOnMatch(true); // This will prevent further execution once a match is found
Macaw::get('/', function() {
echo 'Hello world!';
});
Macaw::dispatch();
echo 'I am further execution...';
If you need to overwrite the HTTP method that's being used for this request, you can set it:, (*9)
Macaw::setMethod('POST');
Lastly, if there is no route defined for a certain location, you can make Macaw run a custom callback, like:, (*10)
Macaw::error(function() {
echo '404 :: Not Found';
});
If you don't specify an error callback, Macaw will just echo 404., (*11)
, (*12)
In order to let the server know the URI does not point to a real file, you may need to use one of the example configuration files., (*13)