应根据校验目标选择函数:需纯十进制数字字符串用ctype_digit()或/^[0-9]+$/,需整数值校验用filter_var($str, filter_validate_int, ['flags' => filter_flag_allow_string]),而is_numeric()语义过宽易误判。

is_numeric() 会把 "123" 和 "1e4" 都当数字,但你可能不需要科学计数法
它判断的是「是否能被解释为数字」,不是「是否是纯十进制整数字符串」。比如 is_numeric("123") 返回 true,但 is_numeric("1e4")、is_numeric("0x1A")、is_numeric(" 42 ") 也都是 true——这些在表单校验或 ID 校验场景里往往属于误判。
- 如果你只要「无符号十进制整数字符串」(如
"123"),别用is_numeric() - 它对空格容忍(自动 trim),对前导零不敏感(
"007"也被接受),但业务上常要求严格格式 - 性能没问题,但语义过宽,容易掩盖格式预期
filter_var($str, FILTER_VALIDATE_INT) 要求整数且可设范围,但默认不接受字符串形式的数字
这个函数本意是验证并转换为 int 类型,所以它会对输入做类型感知处理:filter_var("123", FILTER_VALIDATE_INT) 返回 123(int),但 filter_var("123.0", FILTER_VALIDATE_INT) 就返回 false——哪怕字符串看着像整数。
- 必须配合
FILTER_FLAG_ALLOW_STRING才允许传入字符串(否则"123"会被当成非 int 类型直接拒绝) - 可以加范围限制,比如
filter_var("123", FILTER_VALIDATE_INT, ["options" => ["min_range" => 1, "max_range" => 999]]) - 它不接受带空格、逗号、+ 号前缀的字符串(
" 123"或"+123"都失败)
ctype_digit() 是最接近「纯数字字符串」判断的内置函数
它只认 ASCII 数字字符 0-9,且要求整个字符串非空、无空格、无符号、无小数点——正好对应「纯数字字符串」的直觉定义。
-
ctype_digit("123")→ true -
ctype_digit("007")→ true(前导零合法) -
ctype_digit("-123")、ctype_digit("12.3")、ctype_digit("123 ")、ctype_digit("")全部是 false - 注意:它要求参数是 string,传 int 会警告;且不能处理 Unicode 数字(比如全角数字「123」)
正则 /^[0-9]+$/ 是可控性最强的方式,但要注意 PCRE 模式细节
当你要精确控制格式(比如禁止前导零、限定长度、支持负号等),正则最直接。但别写成 /^\d+$/——\d 在 PHP 的 PCRE 中默认匹配 Unicode 数字,可能意外放过全角或阿拉伯数字。
立即学习“PHP免费学习笔记(深入)”;
- 坚持用
/^[0-9]+$/确保只认 ASCII 数字 - 要支持负数?写成
/^-?[0-9]+$/,但注意"-0"也会通过 - 要禁止前导零(除单独一个
"0")?用/^(0|[1-9][0-9]*)$/ - 性能略低于
ctype_digit(),但差异在纳秒级,实际无感











