cn.hutool.core.util.CreditCodeUtil Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of hutool-all Show documentation
Show all versions of hutool-all Show documentation
Hutool是一个小而全的Java工具类库,通过静态方法封装,降低相关API的学习成本,提高工作效率,使Java拥有函数式语言般的优雅,让Java语言也可以“甜甜的”。
package cn.hutool.core.util;
import cn.hutool.core.lang.PatternPool;
import cn.hutool.core.map.SafeConcurrentHashMap;
import java.util.Map;
import java.util.regex.Pattern;
/**
* 统一社会信用代码(GB32100-2015)工具类
* 标准见:https://www.cods.org.cn/c/2020-10-29/12575.html
*
*
* 第一部分:登记管理部门代码1位 (数字或大写英文字母)
* 第二部分:机构类别代码1位 (数字或大写英文字母)
* 第三部分:登记管理机关行政区划码6位 (数字)
* 第四部分:主体标识码(组织机构代码)9位 (数字或大写英文字母)
* 第五部分:校验码1位 (数字或大写英文字母)
*
*
* @author looly
* @since 5.2.4
*/
public class CreditCodeUtil {
public static final Pattern CREDIT_CODE_PATTERN = PatternPool.CREDIT_CODE;
/**
* 加权因子
*/
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 char[] BASE_CODE_ARRAY = "0123456789ABCDEFGHJKLMNPQRTUWXY".toCharArray();
private static final Map CODE_INDEX_MAP;
static {
CODE_INDEX_MAP = new SafeConcurrentHashMap<>(BASE_CODE_ARRAY.length);
for (int i = 0; i < BASE_CODE_ARRAY.length; i++) {
CODE_INDEX_MAP.put(BASE_CODE_ARRAY[i], i);
}
}
/**
* 正则校验统一社会信用代码(18位)
*
*
* 第一部分:登记管理部门代码1位 (数字或大写英文字母)
* 第二部分:机构类别代码1位 (数字或大写英文字母)
* 第三部分:登记管理机关行政区划码6位 (数字)
* 第四部分:主体标识码(组织机构代码)9位 (数字或大写英文字母)
* 第五部分:校验码1位 (数字或大写英文字母)
*
*
* @param creditCode 统一社会信用代码
* @return 校验结果
*/
public static boolean isCreditCodeSimple(CharSequence creditCode) {
if (StrUtil.isBlank(creditCode)) {
return false;
}
return ReUtil.isMatch(CREDIT_CODE_PATTERN, creditCode);
}
/**
* 是否是有效的统一社会信用代码
*
* 第一部分:登记管理部门代码1位 (数字或大写英文字母)
* 第二部分:机构类别代码1位 (数字或大写英文字母)
* 第三部分:登记管理机关行政区划码6位 (数字)
* 第四部分:主体标识码(组织机构代码)9位 (数字或大写英文字母)
* 第五部分:校验码1位 (数字或大写英文字母)
*
*
* @param creditCode 统一社会信用代码
* @return 校验结果
*/
public static boolean isCreditCode(CharSequence creditCode) {
if (false == isCreditCodeSimple(creditCode)) {
return false;
}
final int parityBit = getParityBit(creditCode);
if (parityBit < 0) {
return false;
}
return creditCode.charAt(17) == BASE_CODE_ARRAY[parityBit];
}
/**
* 获取一个随机的统一社会信用代码
*
* @return 统一社会信用代码
*/
public static String randomCreditCode() {
final StringBuilder buf = new StringBuilder(18);
//
for (int i = 0; i < 2; i++) {
int num = RandomUtil.randomInt(BASE_CODE_ARRAY.length - 1);
buf.append(Character.toUpperCase(BASE_CODE_ARRAY[num]));
}
for (int i = 2; i < 8; i++) {
int num = RandomUtil.randomInt(10);
buf.append(BASE_CODE_ARRAY[num]);
}
for (int i = 8; i < 17; i++) {
int num = RandomUtil.randomInt(BASE_CODE_ARRAY.length - 1);
buf.append(BASE_CODE_ARRAY[num]);
}
final String code = buf.toString();
return code + BASE_CODE_ARRAY[getParityBit(code)];
}
/**
* 获取校验位的值
*
* @param creditCode 统一社会信息代码
* @return 获取校验位的值,-1表示获取错误
*/
private static int getParityBit(CharSequence creditCode) {
int sum = 0;
Integer codeIndex;
for (int i = 0; i < 17; i++) {
codeIndex = CODE_INDEX_MAP.get(creditCode.charAt(i));
if (null == codeIndex) {
return -1;
}
sum += codeIndex * WEIGHT[i];
}
final int result = 31 - sum % 31;
return result == 31 ? 0 : result;
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy