All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.neko233.toolchain.common.business.CreditCodeUtil Maven / Gradle / Ivy

package com.neko233.toolchain.common.business;

import com.neko233.toolchain.common.base.RandomUtils233;
import com.neko233.toolchain.common.base.RegexUtils233;
import com.neko233.toolchain.common.base.StringUtils233;
import com.neko233.toolchain.common.regexPattern.PatternPool;

import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
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 ConcurrentHashMap<>(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 (StringUtils233.isBlank(creditCode)) { return false; } return RegexUtils233.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 = RandomUtils233.randomInt(BASE_CODE_ARRAY.length - 1); buf.append(Character.toUpperCase(BASE_CODE_ARRAY[num])); } for (int i = 2; i < 8; i++) { int num = RandomUtils233.randomInt(10); buf.append(BASE_CODE_ARRAY[num]); } for (int i = 8; i < 17; i++) { int num = RandomUtils233.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