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 / 1458249
Accepted
yog raj
yog raj
Asked: 2019-07-11 06:06:58 +0800 CST2019-07-11 06:06:58 +0800 CST 2019-07-11 06:06:58 +0800 CST

Como descriptografar senhas geradas por "openssl rand -base64 20"

  • 772

Eu preciso gerar várias senhas aleatórias e encontrei o comando "openssl rand -base64 14" que faz a codificação base64 embutida.

sh-3.2# openssl rand -base64 14
ktMgWKno9AbvRUq4wx0=

Mas, uma vez após a geração, gostaria de descriptografar a senha para o formato utilizável/legível por humanos. Mas, ao decodificar, estou vendo apenas valores não legíveis.

sh-3.2# echo ktMgWKno9AbvRUq4wx0= | base64 --decode
�� X����EJ��sh-3.2#

Como vocês descriptografam e usam?

linux passwords
  • 1 1 respostas
  • 4046 Views

1 respostas

  • Voted
  1. Best Answer
    Kamil Maciorowski
    2019-07-11T12:50:30+08:002019-07-11T12:50:30+08:00

    tl;dr

    No método, você encontrou o formato como ktMgWKno9AbvRUq4wx0=legível por humanos; isso é exatamente o que você precisa.


    Resposta detalhada

    descriptografe a senha para um formato utilizável/legível por humanos.

    Um mal-entendido. Duas partes dela:

    1. openssl randgera bytes pseudo-aleatórios . Não há garantia de que serão imprimíveis ou legíveis por humanos.
    2. O ponto principal da codificação Base64 é representar dados binários arbitrários como texto (para que possam ser transportados por canais que suportam apenas conteúdo de texto de maneira confiável). Acontece que o texto é imprimível e legível por humanos.

    Então você pediu (em geral) dados binários codificados como texto. ktMgWKno9AbvRUq4wx0=é a forma legível por humanos. Seu comando para "descriptografar" (ou melhor, "decodificar"; Base64 é uma codificação, não criptografia) é válido, mas fornece os dados binários que a ferramenta produziria sem -base64.

    Você pode usar o que openssl rand -base64 14lhe deu como uma senha legível por humanos. Acho que essa foi a essência da solução que você encontrou. Cada caractere ktMgWKno9AbvRUq4wx0=carrega exatamente 6 bits de entropia da sequência binária original, exceto o imediatamente anterior =e o =próprio: a 0=sequência carrega 4 bits. No total você tem 18×6+4 bits de entropia, isto é exatamente 14×8 que você pediu. A cadeia inteira tem 20 caracteres. Para maximizar (dentro do método) a entropia armazenada em 20 caracteres, você deve exigir pelo menos 20x6 bits e pegar os primeiros 20 caracteres. 20x6 é exatamente 15x8, então este comando

    openssl rand -base64 15
    

    irá gerar exatamente os 20 caracteres que você precisa (sem necessidade de truncamento). Esta será uma string legível por humanos com o mesmo comprimento que a em questão, mas com mais 8 bits de entropia nela.

    Eu disse "maximizar dentro do método" porque "fora do método" é possível empacotar mais entropia por caractere legível por humanos. Se você permitir caracteres adicionais que não pertençam ao conjunto de caracteres Base64 (por exemplo %, _, , #), obterá mais de 6 bits por caractere.

    Você não pode expandir o método com caracteres adicionais porque "6 bits por caractere" é como a base do Base64. Para obter mais entropia por personagem, você precisa de uma abordagem completamente diferente. Um método que usa todos os 95 caracteres ASCII imprimíveis fornecerá cerca de 6,5 bits de entropia por caractere (estritamente: log 2  95).

    • 5

relate perguntas

  • Como eu faria minha máquina Linux parecer que está executando o Windows?

  • Existe um equivalente a cd - para cp ou mv?

  • execute o contêiner do docker como root

  • Como ativar o sensor de impressão digital no domínio e no diretório ativo do Linux

  • Como alterar permanentemente Ctrl + C para Ctrl + K no CentOS 7?

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • 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

    Serviço do Windows 10 chamado AarSvc_70f961. O que é e como posso desativá-lo?

    • 2 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
  • Marko Smith

    ssl.SSLCertVerificationError: falha na verificação do certificado [SSL: CERTIFICATE_VERIFY_FAILED]: não foi possível obter o certificado do emissor local (_ssl.c:1056)

    • 4 respostas
  • Marko Smith

    Como posso saber em qual unidade o Windows está instalado?

    • 6 respostas
  • Martin Hope
    Albin Como faço para ativar o WindowsXP agora que o suporte acabou? 2019-11-18 03:50:17 +0800 CST
  • Martin Hope
    fixer1234 O "HTTPS Everywhere" ainda é relevante? 2019-10-27 18:06:25 +0800 CST
  • Martin Hope
    Kagaratsch O Windows 10 exclui muitos arquivos minúsculos muito lentamente. Algo pode ser feito para agilizar? 2019-09-23 06:05:43 +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
    Inter Sys Como Ctrl+C e Ctrl+V funcionam? 2019-05-15 02:51:21 +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