AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / computer / Perguntas / 1629013
Accepted
dargaud
dargaud
Asked: 2021-02-26 08:19:13 +0800 CST2021-02-26 08:19:13 +0800 CST 2021-02-26 08:19:13 +0800 CST

Que tipo de codificação é essa (variante sha256)?

  • 772

Tenho alguns arquivos de configuração do programa ELOG onde quero alterar a senha manualmente, usando algo como echo -n "newpassword" | sha256summas o valor não é o hexa esperado. Aqui está um extrato de um desses arquivos:

<password encoding="SHA256">vyk1C6u3pcdfTIlvEFSdjvHBiymJBxUuvcZj3BR5Ol/</password>

Que comando posso usar para gerar um hash correto? Isso não está no formato correto:

$ echo -n "newpassword" | sha256sum
089542505d659cecbb988bb5ccff5bccf85be2dfa8c221359079aee2531298bb  -

A senha totodá o hashbfvea3iDok9C0ptb022ndR2uWZUq0BIOH.cVQvSOMUA

encoding hashing
  • 1 1 respostas
  • 1302 Views

1 respostas

  • Voted
  1. Best Answer
    gronostaj
    2021-02-27T06:43:38+08:002021-02-27T06:43:38+08:00

    É SHA256 bruto codificado com algo base64-ish. O comprimento corresponde a base64 de 32 bytes sem preenchimento.

    SHA256 produz uma string de 32 bytes. Essa string geralmente é representada no formato hexadecimal (como 64 caracteres [0-9a-f]), mas não é um requisito. Pode-se optar por usar uma codificação diferente para tornar a string produzida mais curta.

    Base64 pode codificar qualquer string de bytes de 8 bits em uma string que pode ser representada com caracteres ASCII com apenas 33% de sobrecarga de comprimento (em comparação com 100% de sobrecarga para hexadecimal).

    Base64 é bastante simples: primeiro converte a string de bytes de 8 bits em bits, depois divide essa string em bytes de 6 bits. Esses bytes de 6 bits são então representados usando um alfabeto fixo que consiste, nesta ordem:

    • letras maiúsculas A-Z(26 valores 000000..011001)
    • letras minúsculas a-z(26 valores 011010..110011)
    • dígitos 0-9(10 valores 110100..111101)
    • caracteres +e /(111110, 111111)

    para um total de 64 caracteres para representar todos os valores possíveis de um byte de 6 bits. A string resultante é preenchida com um ou dois =caracteres para que o comprimento da string seja um múltiplo de 4. Muitas implementações não requerem o preenchimento para decodificação porque não carrega nenhuma informação.

    Seus hashes de exemplo têm 43 caracteres. Esse comprimento corresponde ao comprimento de base64 não preenchida de uma string de 32 bytes.


    Mas não é tão simples com ELOG! Ao olhar para o código-fonte, você verá que ele usa um alfabeto base64 diferente :

    • personagens .e/
    • dígitos0-9
    • letras maiúsculasA-Z
    • letras minúsculasa-z

    Essa diferença pode ser facilmente contornada usando trpara mapear esses alfabetos. Mas mesmo assim os resultados ainda não coincidem. No seu exemplo, a string totoproduz o hash bfvea3iDok9C0ptb022ndR2uWZUq0BIOH.cVQvSOMUA. Observe os dois caracteres idênticos consecutivos:

    bfvea3iDok9C0ptb022ndR2uWZUq0BIOH.cVQvSOMUA
                     ^^
    

    A string totocodificada com o 'regular' SHA256+base64 não possui estes:

    $ echo -n toto | sha256 | base64            
    MfemXjFVhqwZi9eYtmKc5JA9CJlHbVdBqfMuLlIbamY=
                     ^^
    

    Uma tradução simples preserva a semelhança, então deve haver algo mais em jogo aqui.

    @KamilMaciorowski sugeriu em comentários que algum sal pode estar envolvido. Um salt criptográfico é uma string aleatória por usuário armazenada em texto simples que é anexada à senha antes do hash para que senhas idênticas usadas por usuários diferentes produzam hashes diferentes.

    Você pode mergulhar mais fundo no código para descobrir se o sal é usado e como.

    • 2

relate perguntas

  • Qual é o hash para Utilman.exe

  • Corrigir/reverter a codificação incorreta do arquivo

  • Como codificar em WAV ADPCM?

  • gstreamer usando codificação h264 com tamanho de vídeo pequeno

  • Como esta mensagem de e-mail é codificada?

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Como posso reduzir o consumo do processo `vmmem`?

    • 11 respostas
  • Marko Smith

    Baixar vídeo do Microsoft Stream

    • 4 respostas
  • Marko Smith

    O Google Chrome DevTools falhou ao analisar o SourceMap: chrome-extension

    • 6 respostas
  • Marko Smith

    O visualizador de fotos do Windows não pode ser executado porque não há memória suficiente?

    • 5 respostas
  • Marko Smith

    Como faço para ativar o WindowsXP agora que o suporte acabou?

    • 6 respostas
  • Marko Smith

    Área de trabalho remota congelando intermitentemente

    • 7 respostas
  • Marko Smith

    O que significa ter uma máscara de sub-rede /32?

    • 6 respostas
  • Marko Smith

    Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows?

    • 1 respostas
  • Marko Smith

    O VirtualBox falha ao iniciar com VERR_NEM_VM_CREATE_FAILED

    • 8 respostas
  • Marko Smith

    Os aplicativos não aparecem nas configurações de privacidade da câmera e do microfone no MacBook

    • 5 respostas
  • Martin Hope
    Saaru Lindestøkke Por que os arquivos tar.xz são 15x menores ao usar a biblioteca tar do Python em comparação com o tar do macOS? 2021-03-14 09:37:48 +0800 CST
  • Martin Hope
    CiaranWelsh Como posso reduzir o consumo do processo `vmmem`? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Pesquisa do Windows 10 não está carregando, mostrando janela em branco 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    v15 Por que uma conexão de Internet gigabit/s via cabo (coaxial) não oferece velocidades simétricas como fibra? 2020-01-25 08:53:31 +0800 CST
  • Martin Hope
    andre_ss6 Área de trabalho remota congelando intermitentemente 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney Por que colocar um ponto após o URL remove as informações de login? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca Todos os meus complementos do Firefox foram desativados repentinamente, como posso reativá-los? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK É possível criar um código QR usando texto? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 Altere o nome da ramificação padrão do git init 2019-04-01 06:16:56 +0800 CST

Hot tag

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve