/**
* 计算barcode最后一位
* @param code 12位的barcode
* @return
*/
public static String padBarcode(String code){
if( null == code || code.length() != 12 ){
throw new NullPointerException("code 的位数不对!");
}
//补上位数 code
String code_ = code+"0";
int totalEvent = 0;
int totalCardinal = 0;
char[] resolve = code_.toCharArray();
for( int i = 1; i <= resolve.length; i++ )
{
int temp = Integer.parseInt((resolve[i-1])+"");
if( i % 2 == 0 ){
totalEvent += temp;//偶数和
}else{
totalCardinal += temp;//基数和
}
}
int x = ( totalEvent * 3 ) + totalCardinal;
//取x的值 10最小整数倍的数
int all = x;
if( x % 10 != 0 ){
all = ( (x / 10 +1) * 10);
}
return code+(all-x);
}barcode EAN13 最后一位验证码
最新推荐文章于 2022-07-22 15:56:30 发布
本文介绍了一种计算12位Barcode最后一位校验码的方法。通过解析输入的12位字符串,利用特定算法计算出校验位数值并返回完整的13位Barcode。此算法适用于需要验证或生成标准Barcode的应用场景。
5272

被折叠的 条评论
为什么被折叠?



