Introdução
Neste laboratório, exploraremos a implementação do Algoritmo de Luhn em JavaScript. O Algoritmo de Luhn é comumente usado para validar números de identificação, como números de cartão de crédito, números IMEI e números de identificação de provedores nacionais (National Provider Identifier numbers). Através deste laboratório, você aprenderá como dividir uma string, reverter um array, usar os métodos map(), reduce() e shift() para implementar o Algoritmo de Luhn e, finalmente, determinar se um determinado número de identificação é válido ou não.
Verificação de Luhn (Luhn Check)
Para usar o Algoritmo de Luhn para validação de números de identificação, como números de cartão de crédito, números IMEI, números de identificação de provedores nacionais (National Provider Identifier numbers), siga estes passos:
- Abra o Terminal/SSH e digite
nodepara começar a praticar a codificação. - Use os seguintes métodos:
String.prototype.split(),Array.prototype.reverse(),Array.prototype.map()eparseInt()em combinação para obter um array de dígitos. - Use
Array.prototype.shift()para obter o último dígito. - Use
Array.prototype.reduce()para implementar o Algoritmo de Luhn. - Retorne
truesesumfor divisível por10,falsecaso contrário.
Aqui está o código:
const luhnCheck = (num) => {
const arr = (num + "")
.split("")
.reverse()
.map((x) => parseInt(x));
const lastDigit = arr.shift();
let sum = arr.reduce(
(acc, val, i) =>
i % 2 !== 0 ? acc + val : acc + ((val *= 2) > 9 ? val - 9 : val),
0
);
sum += lastDigit;
return sum % 10 === 0;
};
Você pode testar a função de Verificação de Luhn usando estes exemplos:
luhnCheck("4485275742308327"); // true
luhnCheck(6011329933655299); // true
luhnCheck(123456789); // false
Resumo
Parabéns! Você concluiu o laboratório de Verificação de Luhn. Você pode praticar mais laboratórios no LabEx para aprimorar suas habilidades.