StripPrefixRegex

Removing Prefixes From the Path Before Forwarding the Request (Using a Regex)

Remove the matching prefixes from the URL path.

Configuration Examples

Docker & Swarm

  1. labels:
  2. - "traefik.http.middlewares.test-stripprefixregex.stripprefixregex.regex=/foo/[a-z0-9]+/[0-9]+/"

Kubernetes

  1. apiVersion: traefik.io/v1alpha1
  2. kind: Middleware
  3. metadata:
  4. name: test-stripprefixregex
  5. spec:
  6. stripPrefixRegex:
  7. regex:
  8. - "/foo/[a-z0-9]+/[0-9]+/"

Consul Catalog

  1. - "traefik.http.middlewares.test-stripprefixregex.stripprefixregex.regex=/foo/[a-z0-9]+/[0-9]+/"

File (YAML)

  1. http:
  2. middlewares:
  3. test-stripprefixregex:
  4. stripPrefixRegex:
  5. regex:
  6. - "/foo/[a-z0-9]+/[0-9]+/"

File (TOML)

  1. [http.middlewares]
  2. [http.middlewares.test-stripprefixregex.stripPrefixRegex]
  3. regex = ["/foo/[a-z0-9]+/[0-9]+/"]

Configuration Options

General

The StripPrefixRegex middleware strips the matching path prefix and stores it in a X-Forwarded-Prefix header.

Tip

Use a stripPrefixRegex middleware if your backend listens on the root path (/) but should be exposed on a specific prefix.

regex

The regex option is the regular expression to match the path prefix from the request URL.

For instance, /products also matches /products/shoes and /products/shirts.

If your backend is serving assets (e.g., images or JavaScript files), it can use the X-Forwarded-Prefix header to properly construct relative URLs. Using the previous example, the backend should return /products/shoes/image.png (and not /images.png, which Traefik would likely not be able to associate with the same backend).

Tip

Regular expressions and replacements can be tested using online tools such as Go Playground or the Regex101.

When defining a regular expression within YAML, any escaped character needs to be escaped twice: example\.com needs to be written as example\\.com.