Singapore NRIC / FIN Number Regex for Java
/^([STFGM][0-9]{7}[A-Z])$/What this pattern does
This page provides a lightweight, single-purpose regular expression for matching singapore nric / fin number, ported and verified for Java. Identity and credential patterns need both correctness and safety, since they're frequent targets for adversarial input. The snippet below is ready to drop into your Java project — whether you're validating in a Spring Boot controller, a Jakarta EE service, or a standalone utility class.
Java Implementation
// Singapore NRIC / FIN Number
// ReDoS-safe | RegexVault — Identity & PII > National Identity Numbers
import java.util.regex.Pattern;
public class SingaporeNricFinNumberValidator {
private static final Pattern PATTERN =
Pattern.compile("^([STFGM][0-9]{7}[A-Z])$");
public static boolean validate(String input) {
return PATTERN.matcher(input).matches();
}
// Example
public static void main(String[] args) {
System.out.println(validate("S1234567D")); // true
}
}Test Cases
Matches (Valid) | Rejects (Invalid) |
|---|---|
S1234567D | s1234567D |
T2345678C | S123456D |
F3456789A | S12345678D |
G9876543K | S1234567 |
M1234567E | 1234567D |
| — | X1234567D |
When to use this pattern
This pattern is drawn from the Identity & PII > National Identity Numbers category and carries a ReDoS-safe certification. That matters for Java developers because critical in Java applications since the JVM regex engine uses backtracking and is susceptible to ReDoS without careful pattern design. RegexVault audits patterns against known backtracking attack vectors, ensuring you have the necessary context before using this regex in a high-stakes production environment.
Common Pitfalls
NRIC numbers are extremely sensitive in Singapore — the PDPA specifically restricts their collection to necessity. Never display full NRIC to third parties. The M-series (introduced 2022) is missed by many older validators.
Technical Notes
Prefix: S=born before 2000 (Singapore citizen), T=born 2000+ (Singapore citizen), F=foreign before 2000, G=foreign 2000+, M=foreign 2022+ (new MOM series). The last character is a checksum letter computed via a weighted algorithm. Format validation only — checksum requires the algorithm.
Have a pattern that belongs in the vault?
Submit it for review — community-verified patterns get credited to your GitHub handle. Free submissions join the queue. Priority review available for $15.
Submit a Pattern