/**
* 验证统一社会信用代码
* @param {Object} rule - 校验规则
* @param {String} Code - 统一社会信用代码
* @param {Function} callback - 回调函数
*/
export function checkSocialCreditCode(rule, Code, callback) {
// 定义常量
const CODE_LENGTH = 18;
const WEIGHTED_FACTORS = [1, 3, 9, 27, 19, 26, 16, 17, 20, 29, 25, 13, 8, 24, 10, 30, 28];
const CHAR_SET = '0123456789ABCDEFGHJKLMNPQRTUWXY';
// 检查长度
if (Code.length !== CODE_LENGTH) {
callback(new Error('不是有效的统一社会信用编码!'));
return;
}
// 计算校验和
let total = 0;
for (let i = 0; i < CODE_LENGTH - 1; i++) {
const Ancode = Code.charAt(i);
const Ancodevalue = CHAR_SET.indexOf(Ancode);
total += Ancodevalue * WEIGHTED_FACTORS[i];
}
// 计算校验码
const logicCheckCode = 31 - (total % 31);
let checkCode = logicCheckCode === 31 ? '0' : CHAR_SET.charAt(logicCheckCode);
// 比较校验码
const actualCheckCode = Code.charAt(CODE_LENGTH - 1);
if (checkCode !== actualCheckCode) {
callback(new Error('不是有效的统一社会信用编码!'));
} else {
callback();
}
}
引用方法
import { checkSocialCreditCode } from '@/utils.js'
{
validator: checkSocialCreditCode
}
Vue中methods格式
<template>
<div class="form-group" id="app">
<label for="">统一社会信用编码</label>
<input v-model="socialCreditCode" @change="validateSocialCreditCode">
<div v-if="isValid">有效的统一社会信用编码</div>
<div v-else>不是有效的统一社会信用编码</div>
</div>
</template>
<script>
export default {
data() {
return {
socialCreditCode: '',
isValid: false
};
},
methods: {
validateSocialCreditCode() {
const CODE_LENGTH = 18;
const WEIGHTED_FACTORS = [1, 3, 9, 27, 19, 26, 16, 17, 20, 29, 25, 13, 8, 24, 10, 30, 28];
const CHAR_SET = '0123456789ABCDEFGHJKLMNPQRTUWXY';
let total = 0;
for (let i = 0; i < CODE_LENGTH - 1; i++) {
const Ancode = this.socialCreditCode.charAt(i);
const Ancodevalue = CHAR_SET.indexOf(Ancode);
total += Ancodevalue * WEIGHTED_FACTORS[i];
}
const logicCheckCode = 31 - (total % 31);
let checkCode = logicCheckCode === 31 ? '0' : CHAR_SET.charAt(logicCheckCode);
const actualCheckCode = this.socialCreditCode.charAt(CODE_LENGTH - 1);
this.isValid = checkCode === actualCheckCode;
}
}
};
</script>