先上代码
package com.lj;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.regex.Pattern;
import org.apache.commons.lang3.StringUtils;
//import plugin.template.TemplateStepMeta;
/**
* 统一社会信用代码规则验证器
* @author balizuoan
*
*/
public class UnifiedCodeValidator {
//正则校验 如果想要不区分大小写,就在最后一个数组中加入 abcsefghjklmnpqrtuwxy
private static final String REGEX = "[1-9NY]{1}[1-9]{1}[1-6]{1}[0-9]{5}[0123456789ABCDEFGHJKLMNPQRTUWXY]{10}";
private static final int[] WEIGHT = { 1, 3, 9, 27, 19, 26, 16, 17, 20, 29, 25, 13, 8, 24, 10, 30, 28 };
private static final String BASE_CODE_STRING = "0123456789ABCDEFGHJKLMNPQRTUWXY";
private static final char[] BASE_CODE_ARRAY = BASE_CODE_STRING.toCharArray();
private static final List BASE_CODES = new ArrayList<>();
/**
* 登记管理部门+机构类别代码
* http://www.sohu.com/a/332134717_120209852
*/
private static final List REGIST_CODE = Arrays.asList(
"11", "12", "13", "19",
"21", "29",
"31", "32", "33", "34", "35", "39",
"41", "49",
"51", "52", "53", "59",
"61", "62", "69",
"71", "72", "79",
"81", "89",
"91", "92", "93",
"A1", "A9",
"N1", "N2", "N3", "N9",
"Y1"
);
/**
* 省级行政区划代码
*/
private static final List PROVINCE_REGION_CODE = Arrays.asList(
"11", "12", "13", "14", "15", "21", "22", "23", "31", "32", "33", "34", "35", "36", "37", "41", "42", "43", "44", "45", "46",
"50", "51", "52", "53", "54", "61", "62", "63", "64", "65", "71", "81", "82", "91"
);
static {
for (char c : BASE_CODE_ARRAY) {
BASE_CODES.add(c);
}
}
/**
* 校验方法
* @param value 信用代码
* @return
*/
public boolean CodeValidate( String value) {
if (StringUtils.isEmpty(value)) {
return true;
}
// 长度验证
if (value.length() != 18) {
return false;
}
// 登记管理部门+机构类别代码验证
if (!REGIST_CODE.contains(value.substring(0, 2))) {
return false;
}
// 省级行政区划代码验证
if (!PROVINCE_REGION_CODE.contains(value.substring(2, 4))) {
return false;
}
// 正则初验
if (!Pattern.matches(REGEX, value)) {
return false;
}
// 效验码校验
char[] businessCodeArray = value.toCharArray();
// char check= businessCodeArray[17];
String check = Character.toString(businessCodeArray[17]);
int sum = 0;
for (int i = 0; i < 17; i++) {
char key = businessCodeArray[i];
sum += (BASE_CODES.indexOf(key) * WEIGHT[i]);
}
int checkCode = 31 - sum % 31;
String s = Character.toString(BASE_CODE_ARRAY[checkCode % 31]);
//对比时将两个字符转为字符串,不区分大小写对比最后一位
return s.equalsIgnoreCase(check);
}
}
信用代码编码规则如下:
【统一社会信用代码=登记管理部门代码+机构类别代码+登记管理机关行政区划码+主体标识码(组织机构代码)+校验码】
第一部分(第1位):登记管理部门代码,使用阿拉伯数字或英文字母表示。例如,机构编制、民政、工商三个登记管理部门分别使用1、2、3表示,其他登记管理部门可使用相应阿拉伯数字或英文字母表示。
第二部分(第2位):机构类别代码,使用阿拉伯数字或英文字母表示。登记管理部门根据管理职能,确定在本部门登记的机构类别编码。例如,机构编制部门可用1表示机关单位,2表示事业单位,3表示由中央编办直接管理机构编制的群众团体;民政部门可用1表示社会团体,2表示民办非企业单位,3表示基金会;工商部门可用1表示企业,2表示个体工商户,3表示农民专业合作社。
第三部分(第3—8位):登记管理机关行政区划码,使用阿拉伯数字表示。例如,国家用100000,北京用110000,注册登记时由系统自动生成,体现法人和其他组织注册登记及其登记管理机关所在地,既满足登记管理部门按地区管理需求,也便于社会对注册登记主体所在区域进行识别。(参照《中华人民共和国行政区划代码》[GB/T 2260—2007])
第四部分(第9—17位):主体标识码(组织机构代码),使用阿拉伯数字或英文字母表示。(参照《全国组织机构代码编制规则》[GB 11714—1997])
第五部分(第18位):校验码,使用阿拉伯数字或英文字母表示。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)