URL rewrite examples
The examples in this page illustrate how to rewrite URLs with Transform Rules.
Rewrite path of welcome page for visitors in specific countries
To have a welcome page in two languages, create two rewrite URL rules with a static rewrite of the path component:
Rewrite URL rule #1
Text in Expression Editor:
http.request.uri.path == "/welcome.html" && ip.geoip.country == "GB"
Text after Path > Rewrite to… > Static:
/welcome-gb.html
Rewrite URL rule #2
Text in Expression Editor:
http.request.uri.path == "/welcome.html" && ip.geoip.country == "PT"
Text after Path > Rewrite to… > Static:
/welcome-pt.html
Rewrite URL query string of blog visitors
To rewrite a request to the /blog
path to /blog?sort-by=date
, create a rewrite URL rule with the following settings:
Text in Expression Editor:
http.request.uri.path == "/blog"
Text after Query > Rewrite to… > Static:
sort-by=date
Additionally, set the path rewrite action of the same rule to Preserve so that the URL path does not change.
Rewrite path of archived blog posts
To rewrite all requests to /news/2012/...
to /archive/news/2012/...
you must add a reference to the content of the original URL. Create a new rewrite URL rule and define a dynamic URL path rewrite using an expression:
Text in Expression Editor:
starts_with(http.request.uri.path, "/news/2012/")
Text after Path > Rewrite to… > Dynamic:
concat("/archive", http.request.uri.path)
The filter uses the starts_with()
function all paths starting with /news/2012/
. The dynamic path rewrite uses the concat()
function to concatenate a prefix to the original URL path of the HTTP request.
Rewrite path of moved section of a website
To rewrite everything under /blog/<PATH>
to /marketing/<PATH>
you must modify the first component of the path (/blog/
). Create a rewrite URL rule and use the regex_replace()
function for this purpose:
Text in Expression Editor:
starts_with(http.request.uri.path, "/blog/")
Text after Path > Rewrite to… > Dynamic:
regex_replace(http.request.uri.path, "^/blog/", "/marketing/")
The regex_replace()
function matches the path component on a regular expression (^/blog/
) and then provides a replacement for that match (/marketing/
).
Rewrite path with several URL segments to a different URL segment
To rewrite paths like /images/<FOLDER1>/<FOLDER2>/<FILENAME>
— where <FOLDER1>
, <FOLDER2>
, and <FILENAME>
can vary — to /img/<FILENAME>
, create a rewrite URL rule with a dynamic rewrite of the path component:
Text in Expression Editor:
http.request.uri.path ~ "^/images/[^/]+/[^/]+/[^/]+$"
Text after Path > Rewrite to… > Dynamic:
regex_replace(http.request.uri.path, "^/images/[^/]+/[^/]+/(.+)$", "/img/${1}")
For example, this rule would rewrite the /images/nature/animals/tiger.png
path to /img/tiger.png
.
Rewrite blog archive URLs to support a new URL format
To rewrite the URLs of a blog archive that follow the URL format /posts/<YYYY>-<MM>-<DD>-<TITLE>
to the new format /posts/<YYYY>/<MM>/<DD>/<TITLE>
, create the following rewrite URL rule:
Text in Expression Editor:
http.request.uri.path ~ "^/posts/[0-9]+-[0-9]+-[0-9]+-.*"
Text after Path > Rewrite to… > Dynamic:
regex_replace(http.request.uri.path, "^/posts/([0-9]+)-([0-9]+)-([0-9]+)-(.*)$", "/posts/${1}/${2}/${3}/${4}")
The function regex_replace()
also allows you to extract parts of the URL using regular expressions’ capture groups. Create capture groups by putting part of the regular expression in parentheses. Then, reference a capture group using ${<NUMBER>}
in the replacement string, where <NUMBER>
is the number of the capture group.
Serve images from custom paths
When using Cloudflare Images or Cloudflare Image Resizing, you can use URL rewrites to serve images from a custom path. Refer to the following pages for examples:
- Serve images from custom domains and paths (Cloudflare Images)
- Serve images from custom paths (Cloudflare Image Resizing)