Skip to content

IgberZBN/cifra-de-cesar

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

41 Commits
 
 
 
 
 
 

Repository files navigation

Cifra de cesar

A cifra de César é um método de criptografia simples que consiste em substituir cada letra de uma mensagem por outra letra, que está um número fixo de posições mais adiante no alfabeto. Esse número é conhecido como a chave da cifra. Por exemplo, se a chave for 3, então a letra "A" seria substituída pela letra "D", a letra "B" seria substituída pela letra "E" e assim por diante. A decodificação da mensagem criptografada é feita usando a chave inversa.

Sobre o codigo

Funcionamento da cifra em JavaScript

Resumo

1. Dividir cada letra do texto

const textoSplit = texto.split("");

Primeiramente iremos dividir cada letra do texto, para facilitar a a cifragem. O código que está acima é uma função que divide o texto de entrada (texto) em um array de caracteres. A função cria uma nova variável "textoSplit" que é um array, onde cada elemento representa um caractere do texto original.

A função usa o método split() para dividir o texto original em um array de caracteres. O método split() é usado passando como parâmetro uma string vazia (""), o que indica que o texto deve ser dividido em cada caractere.

Exemplo: texto = "Hello World" textoSplit = ["H", "e", "l", "l", "o", " ", "W", "o", "r", "l", "d"]

Assim, a função retorna um novo array "textoSplit" onde cada elemento representa um caractere do texto original.

2. Transformar letra em número

const textoAscii = textoSplit.map((t)=>{ 
   return t.codePointAt();
})

Logo após dividir cada letra do texto iremos tranformar eles números, esse código é uma função que modifica o texto de entrada (textoSplit) para converter cada caractere em seu valor equivalente na tabela ASCII. A função cria uma nova variável "textoAscii" que é um array, onde cada elemento representa um valor ASCII de cada caractere do texto original.

A função usa o método map() para iterar sobre cada elemento do array "textoSplit" e aplicar a conversão de caractere para valor ASCII. Dentro do map, há uma função que usa o método codePointAt() para retornar o valor ASCII do caractere atual.

Assim, a função retorna um novo array "textoAscii" onde cada elemento representa o valor ASCII correspondente a cada caractere do texto original.

3. Filtragem de dados

const textoFilter = textoAscii.filter((n)=>{
   return (n == 32 || n >= 65 && n<=91);
})

Para filtrar os dados, ultilizaremos a seguinte função, que filtra o texto de entrada (textoAscii) para remover caracteres indesejados(caracteres especiais e numeros...). A função cria uma nova variável "textoFilter" que é um array, onde cada elemento representa um valor ASCII de caracteres válidos.

A função usa o método filter() para iterar sobre cada elemento do array "textoAscii" e aplicar uma lógica de filtragem. Dentro do filter, há uma função que usa uma condição para verificar se o elemento atual é igual a 32 (valor ASCII do espaço em branco) ou se está entre 65 (valor ASCII de "A") e 91 (valor ASCII de "Z"). Se a condição for verdadeira, o elemento é incluído no array "textoFilter", caso contrário, é removido.

Assim, a função retorna um novo array "textoFilter" onde cada elemento representa o valor ASCII correspondente a caracteres válidos do texto original.

4. Substituição/rotação

const textoRotacao = textoFilter.map((n)=>{
    if(n==32){
        return n
    }
    return(n-65+1)%26+65
})

A função usa o método map() para iterar sobre cada elemento do array "textoFilter" e aplicar uma lógica de cifra de césar. Dentro do map, há uma condicional que verifica se o elemento atual é um espaço em branco (valor 32 na tabela ASCII), se for ele é retornado sem modificações. Caso contrário, é aplicada uma lógica para cifrar a letra.

A lógica aplicada é: (n-65+1)%26+65

onde:

  • n é o elemento atual do array
  • 65 é o valor ASCII de "A" (letra inicial do alfabeto)
  • 1 é o valor de rotação (chave)
  • %26 é o operador módulo que divide o número pelo número de letras do alfabeto (26) e retorna o resto da divisão
  • +65 é somado novamente para que o resultado esteja dentro do intervalo de valores ASCII das letras maiúsculas Assim, a função retorna um novo array "textoRotacao" onde cada elemento representa a letra cifrada.

5. Texto cifrado

const textoCifrado = textoRotacao.map((n)=>{
    return String.fromCharCode(n);
})

Por ultimo, para obter o texto cifrado ultilizamos a seguinte função. Função que transforma o texto de entrada (textoRotacao) de valores ASCII para caracteres. A função cria uma nova variável "textoCifrado" que é um array, onde cada elemento representa um caractere do texto cifrado.

A função usa o método map() para iterar sobre cada elemento do array "textoRotacao" e aplicar a conversão de valor ASCII para caractere. Dentro do map, há uma função que usa o método fromCharCode() da classe String para retornar o caractere correspondente ao valor ASCII.

Assim, a função retorna um novo array "textoCifrado" onde cada elemento representa o caractere correspondente ao valor ASCII do texto cifrado.

About

Cifra de cesar feita em JavaScript

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published