Skip to content


Subversion checkout URL

You can clone with
Download ZIP
A low-level router class for PHP based on CodeIgniter's core/Router.php
Branch: master

Added installation instructions to readme

Mainly for GitHub users' benefit
latest commit fe62ed8209
@simonhamp authored



Hi, thanks for checking out Routes! Routes is low-level PHP class for defining and using URL routing patterns similar to CodeIgniter. In fact Routes is based on CodeIgniter's implementation.


You can install via Composer or grab the files and include whichever way you prefer.

require { "simonhamp/routes": "1.0" }


To use Routes, you simply need to place the class somewhere accessible within your application. Then you need to define some routes and register them:


    'testing/(:num)' => 'test/$1',
    'posts/(:any)' => 'news/$1'

  $origin = 'testing/1';
  echo 'Origin: ' . $origin . '<br>';
  echo 'Reroute: ' . Routes::route( $origin );


In-App Routing, as opposed to URL Rewriting (e.g. .htaccess/mod_rewrite), is a popular method for defining patterns for URLs in web sites and applications. It allows the developer to make an app appear one way, but underneath go another. It's most commonly found in MVC web frameworks (Rails, Sinatra, CakePHP, CodeIgniter et al). Routing is simple, but powerful, and could be really useful in situations outside of those frameworks.

There are other attempts at portable routing libraries, but they're too tied into the MVC framework schema to be useful outside. That's where Routes comes in. You could use it as your routing system for yet another framework (like I'm going to :D) or you can keep it completely separate, like I have needed to do lately.

Using Routes you can define complex routes using simple instructions and get the rewritten URL as a return variable in your code. So it doesn't need a specific web server. It doesn't do anything fancy, it just rewrites the URLs you give it according to the rules you supply, in the order you supplied them. Simple.

Hope you find it useful! :)

Questions? Comments? Feel free to open a ticket or message me on Twitter @simonhamp

Something went wrong with that request. Please try again.