URL rewriting
URL rewriting is useful when your application expects “pretty URLs” that map to a single entry script (common in PHP CMS/framework stacks), or when you need to preserve old URL structures after migrations.
Rewrites are applied early in the request pipeline, before proxying or static file serving, so the rewritten URL is used for routing. The client sees no redirect — the rewrite is transparent.
For many applications behind reverse proxy, rewriting is not required. Those apps usually handle routing themselves, and Ferron only forwards requests with proxy (often using location blocks).
Single-page application fallback
A common pattern is rewriting unknown routes to / so client-side routing works:
example.com {
root /var/www/html
rewrite "^/.*" "/" {
last true
directory false
file false
}
}This preserves real files (for example /assets/app.js) while routing non-file paths (for example /dashboard/settings) to your SPA entry point.
PHP front-controller pattern
Many PHP applications route requests through index.php:
example.com {
root /var/www/app/public
rewrite "^/(.*)" "/index.php/$1" {
file false
directory false
last true
}
}This pattern is commonly used by CMS/framework setups where the app resolves routes internally.
Legacy URL migration
To keep old URLs working after restructuring paths:
example.com {
root /var/www/html
rewrite "^/old-path/(.*)" "/new-path/$1" {
last true
}
rewrite "^/blog/([^/]+)/?(?:$|[?#])" "/blog.php?slug=$1" {
last true
}
}Chained rules without last
Without last true, multiple rewrite rules can chain together:
example.com {
rewrite "^/legacy/(.*)" "/modern/$1"
rewrite "^/modern/(.*)" "/current/$1"
}A request to /legacy/foo is first rewritten to /modern/foo, then the second rule rewrites it to /current/foo.
Rewrite troubleshooting
- Use
rewrite_log truewhile debugging to verify which rules match. Each rewrite operation is logged to the error log. - Prefer specific rules before broad catch-all rules.
- Use
file falseanddirectory falsefor front-controller/SPA rewrites so existing files/directories are still served directly. - Rules with
last truestop further processing. - When URL sanitization is enabled (the default), dangerous path sequences are normalized before rewrite rules are applied. If you need raw URL processing, you can disable URL sanitation with
url_sanitize false. - For reverse-proxy routing patterns, see Reverse proxying.
- For directive reference, see Configuration: URL rewriting.