PESEL 校验和验证(Javascript/HTML)

PESEL checksum validation(Javascript/HTML)

我是一名目前在家学习的学生,我严重陷入了校验和问题。该脚本应该验证 PESEL(我认为是社会安全号码的波兰等价物),无论如何校验和的工作方式如下 PESEL: 70051012347

PESEL:7,0,0,5,1,0,1,2,3,4 (7)

  (Multiply each Pesel number by its corresponding check number)

检查:1,3,7,9,1,3,7,9,1,3

 (Sum Each number)

总和:+ 7,0,0,45,1,0,7,18,3,12 =93

MOD: 93 MOD 10 = 3

10 - 3 = 7(比塞尔的最后一位)

其中MOD10不等于0,将10减去sum%10的结果再与原数中的最后一位匹配,匹配则为好,不匹配则为坏的。我只需要有一个好或坏的结果。

我很确定我的代码中的所有这些都很好而且有一个简单的解决方案我只是看不到它。任何帮助都将不胜感激。

<html>
<head>
<meta charset="utf-8">
<title>Pesel Checker</title>
<script type="text/javascript">

function peselgood(y)
{
    //sample PESEL's
    //type 1
    //70051012347
    //02070803628
    //07020803628
    //type 2
    //83102570819
    if (y.length == 11) 
    {

        var arr = [1,3,7,9,1,3,7,9,1,3];
        var sum = 0;

        //hold original number 
        var a = parseInt(y);

        //First 10 digits without check number and convert to array
        y = y.substring(0,9);
        y = parseInt(y);
        var arr1 = new Array(10);
        arr1 = y;

        //muliply pesel digits by checksum digits
        for (var i = 0; i < 10; i++)
        {
          sum += arr[i] * arr1[i];
        }

        sum = sum%10;
        if (sum !== 0)
        {
            sum = 10-sum;
            if(sum != a[10])
            {
                return false;
            }
            else
            {
                return true;
            }
        }
    }
    else
    {
        return false;
    }
}


function checkpesel()
{
    num = document.getElementById("peselfield").value
    if (peselgood(num))
    {
        document.getElementById("peselfield").style.background="#00ff00";
    }
    else
    {
        document.getElementById("peselfield").style.background="#ff6666";
    }
}

</script>


</head>
<body>
    <div>
    Check Sum Template
    <br/><br/>
    <form name="form">
        PESEL: 
        <input type="text" id="peselfield" value="70051012347" /> <button type="button" onclick="checkpesel()">Check</button>
        <br/><br/>
    </form> 
    </div>
    <br/><br/>
</body>
</html>

你犯了几个错误。如果您使用 JavaScript 调试器单步调试您的代码,您将准确地找出问题所在。最重要的事实是,您不必将字符串转换为整数数组。 JavaScript 自动理解何时将字符转换为整数。 这是我的解决方案:

    function peselgood(y)
    {
        if (y.length == 11)
        {
            var arr = [1,3,7,9,1,3,7,9,1,3];
            var sum = 0;

            //muliply pesel digits by checksum digits
            for (var i = 0; i < 10; i++)
            {
                sum += arr[i] * y[i];
            }

            sum = sum%10 == 0 ? 0 : 10-sum%10;
            return sum == y[10];
        }
        else
        {
            return false;
        }
    }

function checksum(p) { let i, s = +p[ i = 10 ]; while( i-- ) s += "1379"[ i % 4 ] * p[i]; return ! ( s % 10 ); }
<input id="pesel" placeholder="PESEL" autofocus>

<input type="button" value="check" onclick="alert( checksum(pesel.value) ? 'Ok' : 'Bad' )">