首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >检查有效的IMEI

检查有效的IMEI
EN

Stack Overflow用户
提问于 2010-03-25 14:59:32
回答 2查看 8.2K关注 0票数 6

有人知道如何检查有效的IMEI吗?

我在这个页面上找到了一个函数:http://www.dotnetfunda.com/articles/article597-imeivalidator-in-vbnet-.aspx

但它返回有效IMEI (f.e. )的false352972024585360)。我可以在这个页面上在线验证它们:http://www.numberingplans.com/?page=analysis&sub=imeinr

检查给定的IMEI是否有效的正确方法(在VB.Net中)是什么?

PS:上述页面中的此功能在某些方面一定是不正确的:

代码语言:javascript
复制
Public Shared Function isImeiValid(ByVal IMEI As String) As Boolean
    Dim cnt As Integer = 0
    Dim nw As String = String.Empty
    Try
        For Each c As Char In IMEI
            cnt += 1
            If cnt Mod 2 <> 0 Then
                nw += c
            Else
                Dim d As Integer = Integer.Parse(c) * 2 ' Every Second Digit has to be Doubled '
                nw += d.ToString() ' Genegrated a new number with doubled digits '
            End If
        Next
        Dim tot As Integer = 0
        For Each ch As Char In nw.Remove(nw.Length - 1, 1)
            tot += Integer.Parse(ch) ' Adding all digits together '
        Next
        Dim chDigit As Integer = 10 - (tot Mod 10) ' Finding the Check Digit my Finding the Remainder of the sum and subtracting it from 10 '
        If chDigit = Integer.Parse(IMEI(IMEI.Length - 1)) Then ' Checking the Check Digit with the last digit of the Given IMEI code '
            Return True
        Else
            Return False
        End If
    Catch ex As Exception
        Return False
    End Try
End Function

编辑:这是我的工作"checkIMEI"-Function:

代码语言:javascript
复制
Public Shared Function checkIMEI(ByRef IMEI As String) As Boolean
    Const allowed As String = "0123456789"

    Dim cleanNumber As New System.Text.StringBuilder
    For i As Int32 = 0 To IMEI.Length - 1
        If (allowed.IndexOf(IMEI.Substring(i, 1)) >= 0) Then
            cleanNumber.Append(IMEI.Substring(i, 1))
        End If
    Next

    If cleanNumber.Length <> 15 Then
        Return False
    Else
        IMEI = cleanNumber.ToString
    End If

    For i As Int32 = cleanNumber.Length + 1 To 16
        cleanNumber.Insert(0, "0")
    Next

    Dim multiplier As Int32, digit As Int32, sum As Int32, total As Int32 = 0
    Dim number As String = cleanNumber.ToString()

    For i As Int32 = 1 To 16
        multiplier = 1 + (i Mod 2)
        digit = Int32.Parse(number.Substring(i - 1, 1))
        sum = digit * multiplier
        If (sum > 9) Then
            sum -= 9
        End If
        total += sum
    Next

    Return (total Mod 10 = 0)
End Function
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-03-25 15:02:02

使用卢恩算法对IMEI数进行验证。链接页面有各种语言的实现。这个职位还提供了一些关于如何解决Luhn算法的实现和一般方法。

票数 11
EN

Stack Overflow用户

发布于 2018-12-31 12:03:09

IMEISV(IMEI软件版本)没有Luhn算法检查数字。相反,它有两个数字显示的软件版本号。IMEI号的格式多年来一直在演变。

维基百科是一个很好的来源,我认为可以看到这些年来格式的变化。如果您查看新的IMEI和IMEISV版本格式,您将看到最终程序集代码(FAC)已经删除,类型分配代码(TAC)增加了8位数。互联网上有免费和商业TAC列表。

可以通过在Luhn算法验证新和旧IMEI数字的基础上查找TAC列表来验证TAC编号。对于旧的IMEI数字,FAC作为2位应该被丢弃,TAC验证应该对6位进行。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2516579

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档