-1

我需要验证 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;
}

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

4

1 回答 1

2

根据维基百科,ICCID 使用Luhn 算法

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

值得庆幸的是,使用该 Wikipedia 页面作为参考,我们自己很容易正确地实现 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");

在 dotnetfiddle.net 上查看

于 2021-05-07T13:20:27.433 回答