zoukankan      html  css  js  c++  java
  • 联通物联网卡ICCID号校验位算法

    C#  算法  luhnNext(联通物联网卡ICCID号,默认最少19位,总长度20位)

    public static int luhnSum(string InVal)
    {
    int evenSum;
    int oddSum;
    bool isEven;
    bool IsOdd = true;
    evenSum = 0;
    oddSum = 0;
    int strLen;
    strLen = InVal.Length;
    int i;
    for (i = strLen; i >= 1; i--)
    {
    int digit;
    digit = int.Parse(InVal.Substring(i - 1, 1));
    if (IsOdd)
    {
    oddSum = oddSum + digit;
    IsOdd = false;
    }
    else
    {
    digit = digit * 2;
    if (digit > 9)
    {
    digit = digit - 9;
    }
    evenSum = evenSum + digit;
    IsOdd = true;
    }

    }
    int luhnSum = (oddSum + evenSum);

    return luhnSum;
    }

    public static int luhnNext(string InVal)
    {
    int luhnNext;
    int rst;
    rst = luhnSum(InVal + 0) % 10;
    if (rst == 0)
    luhnNext = 0;
    else
    luhnNext = 10 - rst;

    return luhnNext;

    }

    VB 的算法  luhnNext(联通物联网卡ICCID号,默认最少19位,总长度20位)

    Function luhnSum(InVal As String) As Integer
    Dim evenSum As Integer
    Dim oddSum As Integer
    Dim isEven As Boolean
    IsOdd = True
    evenSum = 0
    oddSum = 0
    Dim strLen As Integer
    strLen = Len(InVal)
    Dim i As Integer
    For i = strLen To 1 Step -1
    Dim digit As Integer
    digit = CInt(Mid(InVal, i, 1))
    If (IsOdd) Then
    oddSum = oddSum + digit
    IsOdd = False
    Else
    digit = digit * 2
    If (digit > 9) Then
    digit = digit - 9
    End If
    evenSum = evenSum + digit
    IsOdd = True
    End If
    Next i
    luhnSum = (oddSum + evenSum)
    End Function

    Function luhnCheck(InVal As String)
    luhnCheck = (luhnSum(InVal) Mod 10) = 0
    End Function

    Function luhnNext(InVal As String)
    Dim rst
    rst = luhnSum(InVal & 0) Mod 10
    If (rst = 0) Then
    luhnNext = 0
    Else
    luhnNext = 10 - rst
    End If
    End Function

  • 相关阅读:
    Layui数据表格用法
    初识Vue
    使用NPOI导出Excel表
    使用NPOI将Excel表导入到数据库中
    新随笔
    AX2012/D365 SSRS报表开发
    AX2012自定义注释脚本开发
    D365做文件导入导出CSV
    Azure文件上传下载删除(D365可以直接用)
    关于D365/AX2012/C#中的那些json、对象、字符串类型间的转换
  • 原文地址:https://www.cnblogs.com/zhangjunwei87/p/9640603.html
Copyright © 2011-2022 走看看