Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
A low-level router class for PHP based on CodeIgniter's core/Router.php
PHP
branch: master

This branch is 3 commits ahead, 8 commits behind simonhamp:master

Fetching latest commit…

Cannot retrieve the latest commit at this time

Failed to load latest commit information.
.notes
.sparkleshare
readme.markdown
routes.php

readme.markdown

Routes

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.

Usage

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:

<?php
include('inc/routes.php');

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

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

Why?

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! :)

Something went wrong with that request. Please try again.