Maison > Questions et réponses > le corps du texte
Les cartes de crédit et les cartes de débit utilisent-elles cet algorithme de Luhm ?
Dans le paragraphe suivant, il semble que certains numéros de carte ne puissent pas être déterminés correctement.
Qui fait quelque chose de similaire ? Pouvez-vous fournir le code ? Merci
//Description : Vérification Luhm du numéro de carte bancaire
//Règles de vérification Luhm : Numéro de carte bancaire à 16 chiffres (universel à 19 chiffres) :
// 1. Mettre le numéro de carte à 15 (ou 18) chiffres sans chiffre de contrôle dans l'ordre de droite Numéros 1 à 15 (18), les nombres impairs sont multipliés par 2.
// 2. Additionnez tous les chiffres des dizaines du produit des chiffres impairs, plus tous les nombres des chiffres pairs.
// 3. Ajoutez la somme à la somme de contrôle divisible par 10.
//bankno est le numéro de carte bancaire et banknoInfo est p ou d'autres commandes qui affichent des informations rapides
fonction 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;
}
}
PHPz2017-05-19 10:12:36
Cette nouvelle idée de vérification d'algorithme est étonnante. Le code original a-t-il été écrit par un étranger ? Est-ce parce que la situation où le nombre de chiffres est 0 n'est pas prise en compte ?