參考原文https://blog.csdn.net/hdhxby/article/details/56015370 部分錯誤,修改整合了下this
想查詢數據的,請點擊:統一信用代碼查詢地址編碼
查看效驗規則點擊: GB 32100-2015 法人和其餘組織統一社會信用代碼編碼規則.net
代碼實現以下,複製後能夠直接使用驗證。code
var v =new Tyshyxdm().verify('91331081307655191L');
alert(v);
//統一社會信用代碼
function Tyshyxdm() {
this.firstarray = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'];
this.firstkeys = [3, 7, 9, 10, 5, 8, 4, 2];
this.secondarray = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'J', 'K', 'L', 'M', 'N', 'P', 'Q', 'R', 'T', 'U', 'W', 'X', 'Y'];
this.secondkeys = [1, 3, 9, 27, 19, 26, 16, 17, 20, 29, 25, 13, 8, 24, 10, 30, 28];
this.verify = function (str) {
var code = str.toUpperCase();
/*
統一社會信用代碼由十八位的阿拉伯數字或大寫英文字母(不使用I、O、Z、S、V)組成。
第1位:登記管理部門代碼(共一位字符)
第2位:機構類別代碼(共一位字符)
第3位~第8位:登記管理機關行政區劃碼(共六位阿拉伯數字)
第9位~第17位:主體標識碼(組織機構代碼)(共九位字符)
第18位:校驗碼(共一位字符)
*/
if (code.length != 18) {
return false;
}
var reg = /^\w\w\d{6}\w{9}\w$/;
if (!reg.test(code)) {
return false;
}
/*
登記管理部門代碼:使用阿拉伯數字或大寫英文字母表示。
機構編制:1
民政:5
工商:9
其餘:Y
*/
reg = /^[1,5,9,Y]\w\d{6}\w{9}\w$/;
if (!reg.test(code)) {
return false;
}
/*
機構類別代碼:使用阿拉伯數字或大寫英文字母表示。
機構編制機關:11打頭
機構編制事業單位:12打頭
機構編制中央編辦直接管理機構編制的羣衆團體:13打頭
機構編制其餘:19打頭
民政社會團體:51打頭
民政民辦非企業單位:52打頭
民政基金會:53打頭
民政其餘:59打頭
工商企業:91打頭
工商個體工商戶:92打頭
工商農民專業合做社:93打頭
其餘:Y1打頭
*/
reg = /^(11|12|13|19|51|52|53|59|91|92|93|Y1)\d{6}\w{9}\w$/;
if (!reg.test(code)) {
return false;
}
/*
登記管理機關行政區劃碼:只能使用阿拉伯數字表示。按照GB/T 2260編碼。
例如:四川省成都市本級就是510100;四川省自貢市自流井區就是510302。
*/
reg = /^(11|12|13|19|51|52|53|59|91|92|93|Y1)\d{6}\w{9}\w$/;
if (!reg.test(code)) {
return false;
}
/*
主體標識碼(組織機構代碼):使用阿拉伯數字或英文大寫字母表示。按照GB 11714編碼。
在實行統一社會信用代碼以前,之前的組織機構代碼證上的組織機構代碼由九位字符組成。格式爲XXXXXXXX-Y。前面八位被稱爲「本體代碼」;最後一位被稱爲「校驗碼」。校驗碼和本體代碼由一個連字號(-)鏈接起來。以便讓人很容易的看出校驗碼。可是三證合一後,組織機構的九位字符所有被歸入統一社會信用代碼的第9位至第17位,其原有組織機構代碼上的連字號不帶入統一社會信用代碼。
原有組織機構代碼上的「校驗碼」的計算規則是:
例如:某公司的組織機構代碼是:59467239-9。那其最後一位的組織機構代碼校驗碼9是如何計算出來的呢?
第一步:取組織機構代碼的前八位本體代碼爲基數。5 9 4 6 7 2 3 9
提示:若是本體代碼中含有英文大寫字母。則A的基數是10,B的基數是11,C的基數是12,依此類推,直到Z的基數是35。
第二步:取加權因子數值。由於組織機構代碼的本體代碼一共是八位字符。則這八位的加權因子數值從左到右分別是:三、七、九、十、五、八、四、2。
第三步:本體代碼基數與對應位數的因子數值相乘。
5×3=15,9×7=63,4×9=36,6×10=60,
7×5=35,2×8=16,3×4=12,9×2=18
第四步:將乘積求和相加。
15+63+36+60+35+16+12+18=255
第五步:將和數除以11,求餘數。
255÷11=33,餘數是2。
*/
var firstkey = this.calc(code.substr(8), this.firstarray, this.firstkeys, 11);
/*
第六步:用阿拉伯數字11減去餘數,得求校驗碼的數值。當校驗碼的數值爲10時,校驗碼用英文大寫字母X來表示;當校驗碼的數值爲11時,校驗碼用0來表示;其他求出的校驗碼數值就用其自己的阿拉伯數字來表示。
11-2=9,所以此公司完整的組織機構代碼爲 59467239-9。
*/
var firstword;
if (firstkey < 10) {
firstword = firstkey;
}
if (firstkey == 10) {
firstword = 'X';
} else if (firstkey == 11) {
firstword = '0';
}
if (firstword != code.substr(16, 1)) {
return false;
}
/*
校驗碼:使用阿拉伯數字或大寫英文字母來表示。校驗碼的計算方法參照 GB/T 17710。
例如:某公司的統一社會信用代碼爲91512081MA62K0260E,那其最後一位的校驗碼E是如何計算出來的呢?
第一步:取統一社會信用代碼的前十七位爲基數。9 1 5 1 2 0 8 1 21 10 6 2 19 0 2 6 0提示:若是前十七位統一社會信用代碼含有英文大寫字母(不使用I、O、Z、S、V這五個英文字母)。則英文字母對應的基數分別爲:A=十、B=十一、C=十二、D=1三、E=1四、F=1五、G=1六、H=1七、J=1八、K=1九、L=20、M=2一、N=2二、P=2三、Q=2四、R=2五、T=2六、U=2七、W=2八、X=2九、Y=30
第二步:取加權因子數值。由於統一社會信用代碼前面前面有十七位字符。則這十七位的加權因子數值從左到右分別是:一、三、九、2七、1九、2六、1六、1七、20、2九、2五、1三、八、2四、十、30、28
第三步:基數與對應位數的因子數值相乘。
9×1=9,1×3=3,5×9=45,1×27=27,2×19=38,0×26=0,8×16=128
1×17=17,21×20=420,10×29=290,6×25=150,2×13=26,19×8=152
0×23=0,2×10=20,6×30=180,0×28=0
第四步:將乘積求和相加。9+3+45+27+38+0+128+17+420+290+150+26+152+0+20+180+0=1495
第五步:將和數除以31,求餘數。
1495÷31=48,餘數是17。
*/
var secondkey = this.calc(code, this.secondarray, this.secondkeys, 31);
/*
第六步:用阿拉伯數字31減去餘數,得求校驗碼的數值。當校驗碼的數值爲0~9時,就直接用該校驗碼的數值做爲最終的統一社會信用代碼的校驗碼;若是校驗碼的數值是10~30,則校驗碼轉換爲對應的大寫英文字母。對應關係爲:A=十、B=十一、C=十二、D=1三、E=1四、F=1五、G=1六、H=1七、J=1八、K=1九、L=20、M=2一、N=2二、P=2三、Q=2四、R=2五、T=2六、U=2七、W=2八、X=2九、Y=30
由於,31-17=14,因此該公司完整的統一社會信用代碼爲 91512081MA62K0260E。
*/
var secondword = this.secondarray[secondkey];
if (!secondword || secondword != code.substr(17, 1)) {
return false;
}
var word = code.substr(0, 16) + firstword + secondword;
if (code != word) {
return false;
}
return true;
}
this.calc = function (code, array1, array2, b) {
var count = 0;
for (var i = 0; i < array2.length; i++) {
var a = code[i];
count += array2[i] * array1.indexOf(a);
}
var remainder = count % b;
return remainder === 0 ? 0 : b - remainder;
}
}
blog