Versioned API Path Regex Pattern
Matches REST API paths in the /api/v1/, /api/v2.1/ style.
Pattern
^\/api\/v\d+(?:\.\d+)?\/[A-Za-z0-9._~/-]+$Tested examples
/api/v1/users/api/v2.1/products/42/api/v3/orders/cart-items/api/users/v1/users/api/version-one/usersTest it live
Live Regex TesterJS
0 matches/
/g
/api/v1/users /api/v2.1/products/42 /api/v3/orders/cart-items
Use it in your language
Use it in
// JavaScript / Node.js
const regex = /^\/api\/v\d+(?:\.\d+)?\/[A-Za-z0-9._~/-]+$/;
const value = "/api/v1/users";
const isMatch = regex.test(value);
console.log(isMatch); // true / false
// Extract all matches
const matches = value.match(/^\/api\/v\d+(?:\.\d+)?\/[A-Za-z0-9._~/-]+$/g) || [];Tags
Frequently asked questions
How do I use the Versioned API Path regex pattern in JavaScript?
Wrap the pattern in slashes: const re = /^\/api\/v\d+(?:\.\d+)?\/[A-Za-z0-9._~/-]+$/; — then call re.test(value) to check a single value, or value.match(re) to find matches. The "Use it in" snippets above give you the exact code for 9 languages.
Is this versioned api path regex production-ready?
Yes — every pattern in the library is tested against valid and invalid examples. Still, regex is one layer in a defense-in-depth strategy: pair it with server-side validation (e.g. Luhn for credit cards, mod-97 for IBAN, real DNS lookup for emails) for critical inputs.
Why does my pattern fail in another language?
Different regex engines (PCRE, Java, Python, Go's RE2) support slightly different syntax. The most common gotchas: lookbehinds (not in RE2), named groups syntax, and how backslashes need to be escaped inside string literals. The code snippets above already escape correctly for each language.
Can I edit this pattern and test it live?
Yes — use the live tester above. Type your test string and toggle flags (g, i, m, s, u, y) to see matches highlighted instantly, including capture groups.
Related patterns
See all URL →URL
HTTP/HTTPS URL
Validates full HTTP and HTTPS URLs.
URLDomain Name
Validates domain names (e.g., example.com, sub.domain.co.uk)
URLURL Extraction
Extracts all URLs from a text.
URLRelative URL
Relative path with optional query and hash.
URLYouTube Video URL
Matches any standard YouTube URL (watch, embed, shorts, youtu.be) and captures the 11-char video ID.
URLRoot URL Only
Validates base URL without path or parameters.
Browse the full library — 209 tested regex patterns across 16 categories.