在Web应用开发中,身份证号码验证是用户信息录入环节的重要安全保障,尤其在涉及实名认证、金融交易、政务服务等场景时,准确的身份证验证能有效防止虚假信息录入,ASP作为一种经典的Web开发技术,通过自定义函数可实现身份证号码的格式校验、逻辑验证及有效性判断,本文将详细介绍ASP身份证验证代码函数的设计逻辑、实现步骤及注意事项。
身份证号码结构解析
身份证号码分为15位(旧版)和18位(新版)两种格式,其结构具有明确规则,这是验证函数设计的核心依据。
- 15位身份证:由15位数字组成,结构为“6位地址码 + 6位出生日期码(YYMMDD) + 3位顺序码(奇数男性,偶数女性)”,身份证号码“110105490102001”表示1990年1月2日出生,顺序码“001”为男性。
- 18位身份证:在15位基础上增加“18位校验码”和“出生年份扩展为4位(YYYY)”,结构为“6位地址码 + 8位出生日期码(YYYYMMDD) + 3位顺序码 + 1位校验码”,校验码通过ISO 7064:1983.MOD 11-2算法计算得出,取值为0-9或X(代表10)。
验证逻辑设计核心
身份证验证需从“格式校验”和“逻辑校验”两个维度展开,确保号码不仅符合基本格式,且内部逻辑自洽。
格式校验
- 长度验证:15位或18位,非15位则必须为18位。
- 字符验证:15位仅允许数字;18位前17位为数字,第18位允许数字或“X”(不区分大小写)。
逻辑校验
- 出生日期有效性:提取出生日期码,需符合实际日历规则(如月份不超过12,日期不超过当月最大天数,考虑闰年等)。
- 地址码校验:前6位为地址码,需符合行政区划编码规则(GB/T 2260),实际应用中可结合行政区划数据库校验,基础实现可仅验证是否为6位数字。
- 校验码验证(仅18位):根据前17位数字,按MOD 11-2算法计算校验码,与第18位比对是否一致,算法步骤如下:
(1)将前17位数字分别乘以对应权重(7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2);
(2)计算乘积之和;
(3)用11减去总和对11的余数,得到余数(0-10);
(4)根据余数映射校验码(0:1, 1:0, 2:X, 3:9, 4:8, 5:7, 6:6, 7:5, 8:4, 9:3, 10:2)。
ASP函数代码实现
以下是一个完整的ASP身份证验证函数,支持15位和18位号码验证,返回布尔值表示是否有效,并附带详细的错误信息输出(可根据需求调整)。
<%
' 身份证验证函数
' 参数:idNumber - 身份证号码字符串
' 返回值:Boolean - 是否有效,可通过全局变量获取错误信息
Function ValidateIDCard(idNumber)
Dim isValid, lenID, i, sum, weight, modResult, checkCode, dateStr, year, month, day
Dim errorInfo
isValid = True
errorInfo = ""
' 去除前后空格
idNumber = Trim(idNumber)
' 1. 格式校验
lenID = Len(idNumber)
If lenID <> 15 And lenID <> 18 Then
isValid = False
errorInfo = "身份证号码长度错误,应为15位或18位"
ValidateIDCard = isValid
Exit Function
End If
' 15位身份证:仅允许数字
If lenID = 15 Then
For i = 1 To 15
If Not IsNumeric(Mid(idNumber, i, 1)) Then
isValid = False
errorInfo = "15位身份证仅允许数字"
ValidateIDCard = isValid
Exit Function
End If
Next
End If
' 18位身份证:前17位数字,第18位数字或X
If lenID = 18 Then
For i = 1 To 17
If Not IsNumeric(Mid(idNumber, i, 1)) Then
isValid = False
errorInfo = "18位身份证前17位必须为数字"
ValidateIDCard = isValid
Exit Function
End If
Next
If UCase(Mid(idNumber, 18, 1)) <> "X" And Not IsNumeric(Mid(idNumber, 18, 1)) Then
isValid = False
errorInfo = "18位身份证第18位允许数字或X"
ValidateIDCard = isValid
Exit Function
End If
End If
' 2. 出生日期校验
If lenID = 15 Then
' 15位:年份为2位(19YY)
year = "19" & Mid(idNumber, 7, 2)
month = Mid(idNumber, 9, 2)
day = Mid(idNumber, 11, 2)
Else
' 18位:年份为4位
year = Mid(idNumber, 7, 4)
month = Mid(idNumber, 11, 2)
day = Mid(idNumber, 13, 2)
End If
' 校验月份和日期范围
If month < 1 Or month > 12 Then
isValid = False
errorInfo = "身份证月份无效"
ValidateIDCard = isValid
Exit Function
End If
' 校验日期(考虑闰年)
If day < 1 Or day > 31 Then
isValid = False
errorInfo = "身份证日期无效"
ValidateIDCard = isValid
Exit Function
End If
' 闰年判断:能被4整除且不能被100整除,或能被400整除
If month = 2 Then
If (year Mod 4 = 0 And year Mod 100 <> 0) Or (year Mod 400 = 0) Then
If day > 29 Then
isValid = False
errorInfo = "闰年2月日期无效"
ValidateIDCard = isValid
Exit Function
End If
Else
If day > 28 Then
isValid = False
errorInfo = "平年2月日期无效"
ValidateIDCard = isValid
Exit Function
End If
End If
ElseIf month = 4 Or month = 6 Or month = 9 Or month = 11 Then
If day > 30 Then
isValid = False
errorInfo = "小月日期无效"
ValidateIDCard = isValid
Exit Function
End If
End If
' 3. 18位校验码校验
If lenID = 18 Then
weight = Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2)
checkCode = Array("1", "0", "X", "9", "8", "7", "6", "5", "4", "3", "2")
sum = 0
For i = 0 To 16
sum = sum + CInt(Mid(idNumber, i + 1, 1)) * weight(i)
Next
modResult = sum Mod 11
If UCase(Mid(idNumber, 18, 1)) <> checkCode(modResult) Then
isValid = False
errorInfo = "身份证校验码错误"
ValidateIDCard = isValid
Exit Function
End If
End If
ValidateIDCard = isValid
End Function
' 示例调用
Dim testID, isValid
testID = "11010519900307887X" ' 替换为测试身份证号
isValid = ValidateIDCard(testID)
If isValid Then
Response.Write "身份证验证通过"
Else
Response.Write "身份证验证失败:" & errorInfo ' 需提前定义全局变量errorInfo,或修改函数返回错误信息
End If
%>
注意事项与优化方向
- 地址码深度校验:上述代码仅验证地址码为6位数字,实际应用中可引入行政区划数据表,校验地址码是否存在对应行政区划(如省、市、县)。
- 性能优化:若需批量验证身份证,可将校验逻辑封装为COM组件,避免ASP脚本重复解析,提升执行效率。
- 错误信息细化:当前函数仅返回布尔值,可通过修改函数返回包含详细错误信息的字典对象(如Scripting.Dictionary),方便前端定位具体错误类型。
- 15位转18位处理:对于15位身份证,可扩展函数实现转换为18位(规则:在年份前加“19”,顺序码前加“0”,重新计算校验码),兼容旧版数据。
相关问答FAQs
Q1:为什么身份证验证需要校验码?校验码的作用是什么?
A1:校验码是身份证号码的“防伪标识”,通过ISO 7064算法基于前17位数字计算得出,能有效防止身份证号码录入时的抄写错误或恶意篡改,若第18位数字与计算结果不符,说明号码可能被修改过,验证函数会直接判定为无效,确保数据真实性。
Q2:15位身份证和18位身份证在验证时有何主要区别?
A2:主要区别在于格式和校验逻辑:
- 格式:15位无校验码且出生年份为2位(如“90”代表1990年),18位有校验码且出生年份为4位(如“1990”);
- 校验逻辑:15位无需校验码验证,仅需校验长度、字符及出生日期;18位需额外校验前17位与第18位的校验码是否匹配,且出生日期需完整4位年份,便于判断是否超过合理年龄范围(如1900年至今)。
原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/54302.html