Validationpopular
Medium Password Regex Pattern
6+ characters with at least 2 character types.
Pattern
^(?:(?=.*[A-Z])(?=.*[a-z])|(?=.*[A-Za-z])(?=.*\d))[A-Za-z\d@$!%*?&]{6,}$Tested examples
abc123Passw0rdHELLO1abcde123456!!!!!!Test it live
Live Regex TesterJS
0 matches/
/g
abc123 Passw0rd HELLO1
Use it in your language
Use it in
// JavaScript / Node.js
const regex = /^(?:(?=.*[A-Z])(?=.*[a-z])|(?=.*[A-Za-z])(?=.*\d))[A-Za-z\d@$!%*?&]{6,}$/;
const value = "abc123";
const isMatch = regex.test(value);
console.log(isMatch); // true / false
// Extract all matches
const matches = value.match(/^(?:(?=.*[A-Z])(?=.*[a-z])|(?=.*[A-Za-z])(?=.*\d))[A-Za-z\d@$!%*?&]{6,}$/g) || [];Tags
Frequently asked questions
How do I use the Medium Password regex pattern in JavaScript?
Wrap the pattern in slashes: const re = /^(?:(?=.*[A-Z])(?=.*[a-z])|(?=.*[A-Za-z])(?=.*\d))[A-Za-z\d@$!%*?&]{6,}$/; — 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 medium password 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 Validation →Validation
Username
3-16 characters: letters, numbers, _ and -
ValidationUUID/GUID
Universally Unique Identifier format.
ValidationBasic Accented Text
Accented letters + digits + simple punctuation.
ValidationURL-friendly Slug
Slug for URLs (lowercase, hyphens).
ValidationCSS RGB / RGBA Color
Validates RGB and RGBA CSS color notation. Allows optional alpha 0–1.
ValidationAlphanumeric with Spaces
Allows only letters, numbers, and spaces — no special characters.
Browse the full library — 300 tested regex patterns across 16 categories.