正确的ICCID算法

Posted

技术标签:

【中文标题】正确的ICCID算法【英文标题】:Correct ICCID algo 【发布时间】:2021-05-07 12:54:29 【问题描述】:

我需要验证 ICCID,我发现只有一个算法:

int numberStringLength = 18;

int cs = 0;
int dodd;
for (int i = 0; i < numberStringLength; i += 2)

    dodd = Convert.ToInt32(iccid.Substring(i + 1, 1)) << 1;
    cs += Convert.ToInt32(iccid.Substring(i, 1)) + (int)(dodd / 10) + (dodd % 10);

cs = (10-(cs % 10)) % 10;

if (cs == Convert.ToInt32(iccid.Substring(numberStringLength, 1)))

    return true;

else

    return false;

但它返回false 100% 正确的 ICCID (89148000005339755555)。我在哪里可以获得真正的 ICCID 算法? 谢谢

【问题讨论】:

我不理解您的问题。首先,你有没有调试过这段代码,如果没有,我强烈推荐。其次,如果我是正确的,您想验证 ICCID,对吗?第三,根据您发现正确的算法,您的输出不正确?您还要求真正的 ICCID 算法这是什么意思? 您是否调试过代码并检查哪个计算没有按照预期给出结果? @Codexer 对于有效的 ICCID,此算法返回“假” 不检查代码,我建议参考 ICCID 本身,看看它是如何构建的。它由 18 - 22 个字符组成(17 到 21 + 1 个校验位)。在您的情况下,您假设长度是静态的(18 位数字)。 你已经可以找到答案here 了。 【参考方案1】:

根据Wikipedia,ICCID 使用Luhn algorithm。

您发现的代码有点损坏,因为它假定该值具有奇数位(偶数位正常数字,加上 1 个校验位)。它从最左边的数字开始解析值,并假设这个最左边的数字(在您的示例中为“8”)没有加倍,而下一个(“9”)则加倍。但是,如果该值具有偶数位数,则这是不正确的。在您的情况下,“8”应该是加倍的。

谢天谢地,使用***页面作为参考,我们自己很容易正确地实现 Luhn 算法:

string input = "89148000005339755555";

int sum = 0;
// We'll use index i = 0 means the right-most digit, i = 1 is second-right, etc
for (int i = 0; i < input.Length; i++)

    // Get the digit at the i'th position from the right
    int digit = int.Parse(input[input.Length - i - 1].ToString());

    // If it's in an odd position (starting from the right), then double it.
    if (i % 2 == 1)
    
        digit *= 2;

        // If it's now >= 10, subtract 9
        if (digit >= 10)
        
            digit -= 9;
        
    

    sum += digit;


// It's a pass if the result is a multiple of 10
bool pass = sum % 10 == 0;
Console.WriteLine(pass ? "Pass" : "Fail");

See it on dotnetfiddle.net.

【讨论】:

它为00000000000000000000 返回“通过”。对于 luhn 算法,它可能是正确的值,但它不适合业务流程 :) 这是正确的,遵循 Luhn 算法,如果您阅读它。它在该 Wiki 页面的优缺点部分中明确指出

以上是关于正确的ICCID算法的主要内容,如果未能解决你的问题,请参考以下文章

iccid码怎么查?

什么是ICCID?关于ICCID详解

iccid码怎么查?

怎么改ICCID

手机取证为啥要获取Iccid

使用正则表达式从字符串中提取 ICCID