Javascript - JS-Verifizierung, Kreditkarte und Debitkarte?
ringa_lee
ringa_lee 2017-05-19 10:10:36
0
1
721

Verwenden sowohl Kreditkarten als auch Debitkarten diesen Luhm-Algorithmus?
Im folgenden Absatz scheinen einige Kartennummern nicht korrekt ermittelt zu werden.
Wer macht so etwas Ähnliches? Danke

//Beschreibung: Luhm-Verifizierung der Bankkartennummer
//Luhm-Verifizierungsregeln: 16-stellige Bankkartennummer (19-stellig universell):
// 1. Geben Sie die 15- (oder 18-stellige) Kartennummer ohne Prüfziffer ein Reihenfolge von rechts: Zahlen 1 bis 15 (18), Zahlen in ungeraden Zahlen werden mit 2 multipliziert.
// 2. Addiere alle Zehnerstellen des Produkts aus ungeraden Ziffern plus alle Zahlen in den geraden Ziffern.
// 3. Addiere die Summe zur durch 10 teilbaren Prüfsumme.
//bankno ist die Bankkartennummer und banknoInfo ist p oder andere Steuerelemente, die sofortige Informationen anzeigen

Funktion luhmCheck(bankno){

var lastNum=bankno.substr(bankno.length-1,1);//取出最后一位(与luhm进行比较)

var first15Num=bankno.substr(0,bankno.length-1);//前15或18位
var newArr=new Array();
for(var i=first15Num.length-1;i>-1;i--){    //前15或18位倒序存进数组
    newArr.push(first15Num.substr(i,1));
}
var arrJiShu=new Array();  //奇数位*2的积 <9
var arrJiShu2=new Array(); //奇数位*2的积 >9

var arrOuShu=new Array();  //偶数位数组
for(var j=0;j<newArr.length;j++){
    if((j+1)%2==1){//奇数位
        if(parseInt(newArr[j])*2<9)
        arrJiShu.push(parseInt(newArr[j])*2);
        else
        arrJiShu2.push(parseInt(newArr[j])*2);
    }
    else //偶数位
    arrOuShu.push(newArr[j]);
}

var jishu_child1=new Array();//奇数位*2 >9 的分割之后的数组个位数
var jishu_child2=new Array();//奇数位*2 >9 的分割之后的数组十位数
for(var h=0;h<arrJiShu2.length;h++){
    jishu_child1.push(parseInt(arrJiShu2[h])%10);
    jishu_child2.push(parseInt(arrJiShu2[h])/10);
}        

var sumJiShu=0; //奇数位*2 < 9 的数组之和
var sumOuShu=0; //偶数位数组之和
var sumJiShuChild1=0; //奇数位*2 >9 的分割之后的数组个位数之和
var sumJiShuChild2=0; //奇数位*2 >9 的分割之后的数组十位数之和
var sumTotal=0;
for(var m=0;m<arrJiShu.length;m++){
    sumJiShu=sumJiShu+parseInt(arrJiShu[m]);
}

for(var n=0;n<arrOuShu.length;n++){
    sumOuShu=sumOuShu+parseInt(arrOuShu[n]);
}

for(var p=0;p<jishu_child1.length;p++){
    sumJiShuChild1=sumJiShuChild1+parseInt(jishu_child1[p]);
    sumJiShuChild2=sumJiShuChild2+parseInt(jishu_child2[p]);
}      
//计算总和
sumTotal=parseInt(sumJiShu)+parseInt(sumOuShu)+parseInt(sumJiShuChild1)+parseInt(sumJiShuChild2);

//计算Luhm值
var k= parseInt(sumTotal)%10==0?10:parseInt(sumTotal)%10;        
var luhm= 10-k;

if(lastNum==luhm){

return true;
}
else{

return false;
}        

}

ringa_lee
ringa_lee

ringa_lee

Antworte allen(1)
PHPzhong

这个算法验证的新思路厉害的,原码是老外写的吧?是不是和没把位数是0的情况考虑进去?

Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage