大家好,又见面了,我是你们的朋友全栈君。
电话号码:1开头,后面10位数字
static bool isPhone(String input) {
RegExp mobile = new RegExp(r"1[0-9]\d{9}$");
return mobile.hasMatch(input);
}
复制代码
登录密码:6~16位数字和字符组合
static bool isLoginPassword(String input) {
RegExp mobile = new RegExp(r"(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]{6,16}$");
return mobile.hasMatch(input);
}
复制代码
登录密码:6位数字验证码
static bool isValidateCaptcha(String input) {
RegExp mobile = new RegExp(r"\d{6}$");
return mobile.hasMatch(input);
}
复制代码
带校验的身份证
static bool isCardId(String cardId) {
if (cardId.length != 18) {
return false; // 位数不够
}
// 身份证号码正则
RegExp postalCode = new RegExp(
r'^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|[Xx])$');
// 通过验证,说明格式正确,但仍需计算准确性
if (!postalCode.hasMatch(cardId)) {
return false;
}
//将前17位加权因子保存在数组里
final List idCardList = ["7", "9", "10", "5", "8", "4", "2", "1", "6", "3", "7", "9", "10", "5", "8", "4", "2"];
//这是除以11后,可能产生的11位余数、验证码,也保存成数组
final List idCardYArray = ['1', '0', '10', '9', '8', '7', '6', '5', '4', '3', '2'];
// 前17位各自乖以加权因子后的总和
int idCardWiSum = 0;
for (int i = 0; i < 17; i++) {
int subStrIndex = int.parse(cardId.substring(i, i + 1));
int idCardWiIndex = int.parse(idCardList[i]);
idCardWiSum += subStrIndex * idCardWiIndex;
}
// 计算出校验码所在数组的位置
int idCardMod = idCardWiSum % 11;
// 得到最后一位号码
String idCardLast = cardId.substring(17, 18);
//如果等于2,则说明校验码是10,身份证号码最后一位应该是X
if (idCardMod == 2) {
if (idCardLast != 'x' && idCardLast != 'X') {
return false;
}
} else {
//用计算出的验证码与最后一位身份证号码匹配,如果一致,说明通过,否则是无效的身份证号码
if (idCardLast != idCardYArray[idCardMod]) {
return false;
}
}
return true;
}
复制代码
转载于:https://juejin.im/post/5cb986355188251b194880bc
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/106871.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...