zoukankan
html css js c++ java
身份证号码验证
using
System;
/**/
///
<summary>
///
Summary description for IDCardValid
///
</summary>
public
class
IDCardValid
{
public
IDCardValid()
{
//
//
TODO: Add constructor logic here
//
}
/**/
///
<summary>
///
验证身份证号码
///
</summary>
///
<param name="Id">
身份证号码
</param>
///
<returns>
验证成功为True,否则为False
</returns>
public
static
bool
CheckIDCard(
string
Id)
{
if
(Id.Length
==
18
)
{
bool
check
=
CheckIDCard18(Id);
return
check;
}
else
if
(Id.Length
==
15
)
{
bool
check
=
CheckIDCard15(Id);
return
check;
}
else
{
return
false
;
}
}
身份证号码验证
#region
身份证号码验证
/**/
///
<summary>
///
验证15位身份证号
///
</summary>
///
<param name="Id">
身份证号
</param>
///
<returns>
验证成功为True,否则为False
</returns>
private
static
bool
CheckIDCard18(
string
Id)
{
long
n
=
0
;
if
(
long
.TryParse(Id.Remove(
17
),
out
n)
==
false
||
n
<
Math.Pow(
10
,
16
)
||
long
.TryParse(Id.Replace(
'
x
'
,
'
0
'
).Replace(
'
X
'
,
'
0
'
),
out
n)
==
false
)
{
return
false
;
//
数字验证
}
string
address
=
"
11x22x35x44x53x12x23x36x45x54x13x31x37x46x61x14x32x41x50x62x15x33x42x51x63x21x34x43x52x64x65x71x81x82x91
"
;
if
(address.IndexOf(Id.Remove(
2
))
==
-
1
)
{
return
false
;
//
省份验证
}
string
birth
=
Id.Substring(
6
,
8
).Insert(
6
,
"
-
"
).Insert(
4
,
"
-
"
);
DateTime time
=
new
DateTime();
if
(DateTime.TryParse(birth,
out
time)
==
false
)
{
return
false
;
//
生日验证
}
string
[] arrVarifyCode
=
(
"
1,0,x,9,8,7,6,5,4,3,2
"
).Split(
'
,
'
);
string
[] Wi
=
(
"
7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2
"
).Split(
'
,
'
);
char
[] Ai
=
Id.Remove(
17
).ToCharArray();
int
sum
=
0
;
for
(
int
i
=
0
; i
<
17
; i
++
)
{
sum
+=
int
.Parse(Wi[i])
*
int
.Parse(Ai[i].ToString());
}
int
y
=
-
1
;
Math.DivRem(sum,
11
,
out
y);
if
(arrVarifyCode[y]
!=
Id.Substring(
17
,
1
).ToLower())
{
return
false
;
//
校验码验证
}
return
true
;
//
符合GB11643-1999标准
}
/**/
///
<summary>
///
验证18位身份证号
///
</summary>
///
<param name="Id">
身份证号
</param>
///
<returns>
验证成功为True,否则为False
</returns>
private
static
bool
CheckIDCard15(
string
Id)
{
long
n
=
0
;
if
(
long
.TryParse(Id,
out
n)
==
false
||
n
<
Math.Pow(
10
,
14
))
{
return
false
;
//
数字验证
}
string
address
=
"
11x22x35x44x53x12x23x36x45x54x13x31x37x46x61x14x32x41x50x62x15x33x42x51x63x21x34x43x52x64x65x71x81x82x91
"
;
if
(address.IndexOf(Id.Remove(
2
))
==
-
1
)
{
return
false
;
//
省份验证
}
string
birth
=
Id.Substring(
6
,
6
).Insert(
4
,
"
-
"
).Insert(
2
,
"
-
"
);
DateTime time
=
new
DateTime();
if
(DateTime.TryParse(birth,
out
time)
==
false
)
{
return
false
;
//
生日验证
}
return
true
;
//
符合15位身份证标准
}
#endregion
}
查看全文
相关阅读:
作业四:结对编程项目---四则运算
作业三: 代码规范、代码复审、PSP
自动生成四则运算题目
源程序版本管理软件和项目管理软件的优缺点
学习进度表
第一周随笔
对之前问题的回答
结对编程——四则运算
PSP
代码复审
原文地址:https://www.cnblogs.com/yangbin1005/p/1157006.html
最新文章
模板总结(不定期更新)
网络流 学习笔记 ①
KMP 字符串匹配 学习笔记
高斯-约旦消元法 理解
BZOJ 2622 深入虎穴 题解
BZOJ 5056 OI游戏题解
[数学]gcd&exgcd
[凸包] [旋转卡壳]凸包的构建与直径
[基环树] NOIP2018 旅行
[完全背包] NOIP2018 货币系统
热门文章
[贪心] NOIP2018 铺设道路
NOIP 2018提高 受虐记
【线段树详解】[洛谷P1816][洛谷P3372][[2016常州一中夏令营Day7]序列][CF558E][CF787D]从入门到各种实用技巧
【树状数组详解】[洛谷P3374][洛谷P3368][POJ3321]从入门到各种实用技巧
极大容量的完全背包问题
luogu1484 种树
luogu2891 [USACO07OPEN]吃饭Dining
bzoj3998 [TJOI2015]弦论
《软件工程》课程总结
附加题:
Copyright © 2011-2022 走看看