Mod31算法的javascript实现

  Mod31算法用于国标GB32100-2015 《法人和其他组织统一社会信用代码编码规则》的代码的验证。具体如”三证合一“后的营业执照上代码的验证。


  Mod31算法Javascript实现:

function mod31(sCode){
	var w = [1, 3, 9, 27, 19, 26, 16, 17, 20, 29, 25, 13, 8, 24, 10, 30, 28];
	var c = '0123456789ABCDEFGHJKLMNPQRTUWXY';
	var sum = 0;
	for (var i = 0; i < 17; i++){
		sum += c.indexOf(sCode.charAt(i)) * w[i];
	}
	var r = 31 - (sum % 31);
 	if(r == 31) c18 = '0';
 	else c18 = c.charAt(r);
	return c18;
}


  验证示例:


// 参数:待验证的代码
// 返回:验证成功返回true,否则返回false
function validate(sCode){
	if(! /^[\dABCDEFGHJKLMNPQRTUWXY]{2}\d{6}[\dABCDEFGHJKLMNPQRTUWXY]{10}$/.test(sCode)) return false;
	return sCode.charAt(17) == mod31(sCode);
}
alert(validate('91350100M000100Y43'));




  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值