asp.net 中国身份证号码验证代码 非正则

 更新时间:2009年11月02日 13:48:49   作者:  
asp.net 中国身份证号码验证,需要的朋友可以参考下。
复制代码 代码如下:

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
}

相关文章

  • asp将本地的文件上传到服务器

    asp将本地的文件上传到服务器

    如果你想把自己机器的图片或者文件放到服务器上该怎么办呢?<BR>可选有三种办法ftp上传、用u盘拷贝到服务器上、如果服务器支持asp上传功能,用网页浏览器将文件上传到服务器上
    2015-09-09
  • ASP.NET MVC5网站开发文章管理架构(七)

    ASP.NET MVC5网站开发文章管理架构(七)

    继上一篇把member的用户部分完成,现在开始做文章管理部分。文章部分根据涉及显示现实文章列表,发布文章,修改和删除文章等功能。最终的实现目标是使用权限来控制用户是否能进行相应操作,管理员权限的会显示全部文章列表和我的文章列表,普通用户只显示我的文章列表
    2015-09-09
  • Asp.Net Core WebAPI使用Swagger时API隐藏和分组详解

    Asp.Net Core WebAPI使用Swagger时API隐藏和分组详解

    这篇文章主要给大家介绍了关于Asp.Net Core WebAPI使用Swagger时API隐藏和分组的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Asp.Net Core具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-04-04
  • 利用Aspose.Cells实现万能导出功能

    利用Aspose.Cells实现万能导出功能

    这篇文章主要为大家详细介绍了利用Aspose.Cells实现万能导出功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-12-12
  • 如何在.Net6 web api中记录每次接口请求的日志

    如何在.Net6 web api中记录每次接口请求的日志

    .net6有自带的logging组件,还有很多优秀的开源log组件,如NLog,serilog,这里我们使用serilog组件来构建日志模块,这篇文章主要介绍了如何在.Net6 web api中记录每次接口请求的日志,需要的朋友可以参考下
    2023-06-06
  • Asp.net 连接MySQL的实现代码[]

    Asp.net 连接MySQL的实现代码[]

    ASP.NET连接MySQL需要一个组件(.net本身不提供访问MySQL的驱动)MySQL.Data.Dll,此为官方提供(纯C#开发,开源噢),有多个版本选择,采用的数据访问模式为ADO.NET,跟asp.net访问sqlserver很像,非常简单。
    2009-08-08
  • 使用FreeHost SQL2000网页管理器出错解决办法

    使用FreeHost SQL2000网页管理器出错解决办法

    在您登陆FreeHost SQL2000网页管理器时,如果提示以下信息: 发生类型为 System.Web.HttpUnhandledException 的异常
    2012-01-01
  • Visual Studio寻找C#程序必要的运行库文件

    Visual Studio寻找C#程序必要的运行库文件

    这篇文章主要为大家详细介绍了Visual Studio寻找C#程序必要的运行库文件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05
  • Asp.net 获取指定目录下的后缀名为".doc" 的所有文件名和文件路径

    Asp.net 获取指定目录下的后缀名为".doc" 的所有文件名和文件路径

    Asp.net 获取指定目录下的后缀名为“.doc” 的所有文件名和文件路径,帮写一个方法
    2011-07-07
  • ASP.NET过滤类SqlFilter,防止SQL注入

    ASP.NET过滤类SqlFilter,防止SQL注入

    本文分享一个防SQL注入的过滤类SqlFilter,可以防止通过POST、GET和Cookies的注入。
    2016-03-03

最新评论