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 / unix / Perguntas / 407700
Accepted
Roger Lipscombe
Roger Lipscombe
Asked: 2017-11-30 02:23:22 +0800 CST2017-11-30 02:23:22 +0800 CST 2017-11-30 02:23:22 +0800 CST

Verifique o hash de senha no script bash?

  • 772

Relacionado a Por que a senha de root no Linux Mint é minha senha de usuário?

Parece que minha caixa Mint 17.3 tem uma senha de root definida: vejo um hash de senha em /etc/shadow(começa com $6$...). Eu gostaria de comparar este hash de senha com minha senha de usuário (conhecida).

Por qualquer motivo, não confio su -(na pergunta vinculada) para não usar minha senha, em vez da senha root .

Existe uma maneira simples (no bash, por exemplo) de comparar um hash conhecido com uma senha conhecida e ver se eles correspondem?

bash password
  • 3 3 respostas
  • 6195 Views

3 respostas

  • Voted
  1. Best Answer
    Henrik supports the community
    2017-11-30T04:27:57+08:002017-11-30T04:27:57+08:00

    Encontre o sal usado em /etc/shadow, são os caracteres entre o segundo e o terceiro $, geralmente serão oito.

    Use mkpasswd -m sha-512 -S <salt>e digite a senha que você acha que deveria ser quando for solicitado. Ele produzirá o hash com $6$<salt>$prefixado.

    • 3
  2. Stéphane Chazelas
    2017-11-30T06:52:56+08:002017-11-30T06:52:56+08:00

    No final, você precisa chamar a crypt(3)função do libcrypt(que em sistemas GNU como o Linux Mint vem com o GNU libc) com a senha como primeiro argumento e o hash ( $6$...) como segundo argumento.

    pythoné uma dessas ferramentas que expõe essa função, então você pode fazer:

    HASH='$6$...' python2 -c 'import crypt, os, getpass
    print(crypt.crypt(getpass.getpass(), os.environ["HASH"]))'
    

    E se a saída corresponder ao hash, essa era a senha correta.

    $HASHacima pode ser o hash completo (como $6$rounds=1234$somesalt$6eFBNhSgwEwdfZBHueBedpcqaVKGcV2DJy/tQMFd3JL88hwvgTkISJShnOUrbtP1fRs8I9rGIdsgWCoiujxD2/) ou apenas a parte dele mais à direita $, incluindo o sal e a contagem de rodadas opcional ( $6$rounds=1234$somesalt$).

    Ou você pode fazer a verificação em python:

    HASH='$6$...' python2 -c '
    import crypt, os, getpass
    hash = os.environ["HASH"]
    if crypt.crypt(getpass.getpass(), hash) == hash:
      print "OK"
    else:
      print "Wrong password"'
    

    (então, obviamente, $HASHdeve conter o hash completo).

    Com python, você também pode chamar funções de bibliotecas arbitrárias usando o ctypesmódulo. Portanto, outra maneira de chamar a crypt()função do sistema (não que você precise, pois crypté um dos módulos padrão, é só que antes eu tinha a impressão de que o cryptmódulo vinha com sua própria crypt()implementação separada) é com algo como:

    HASH='$6$...' python2 -c '
    from ctypes import *
    import os, getpass
    l = CDLL("libcrypt.so.1")
    l.crypt.restype = c_char_p
    print l.crypt(getpass.getpass(), os.environ["HASH"])'
    
    • 3
  3. Ulrich Schwarz
    2017-11-30T02:28:00+08:002017-11-30T02:28:00+08:00

    ssh root@localhostvem à mente, embora sua distribuição possa ter desabilitado totalmente o login baseado em senha para root e/ou instalado um par de chaves; ou fazer login em sua tela de login gráfica usual como usuário root. (Mesmo se você tiver o login automático ativado, a caixa de diálogo de desligamento pode oferecer o login como outro usuário.)

    • 0

relate perguntas

  • exportar variáveis ​​​​env programaticamente, via stdout do comando [duplicado]

  • Problema estranho ao passar variáveis ​​do arquivo de texto

  • Enquanto a linha lê mantendo os espaços de escape?

  • ordem de substituição de processos `te` e `bash`

  • Execute um script muito lento até que seja bem-sucedido

Sidebar

Stats

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

    Matriz JSON para bash variáveis ​​usando jq

    • 4 respostas
  • Marko Smith

    A data pode formatar a hora atual para o fuso horário GMT? [duplicado]

    • 2 respostas
  • Marko Smith

    bash + lê variáveis ​​e valores do arquivo pelo script bash

    • 4 respostas
  • Marko Smith

    Como posso copiar um diretório e renomeá-lo no mesmo comando?

    • 4 respostas
  • Marko Smith

    conexão ssh. Conexão X11 rejeitada devido a autenticação incorreta

    • 3 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Marko Smith

    comando systemctl não funciona no RHEL 6

    • 3 respostas
  • Marko Smith

    rsync porta 22 e 873 uso

    • 2 respostas
  • Marko Smith

    snap /dev/loop em 100% de utilização -- sem espaço livre

    • 1 respostas
  • Marko Smith

    chave de impressão jq e valor para todos no subobjeto

    • 2 respostas
  • Martin Hope
    EHerman Matriz JSON para bash variáveis ​​usando jq 2017-12-31 14:50:58 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Drux A data pode formatar a hora atual para o fuso horário GMT? [duplicado] 2017-12-26 11:35:07 +0800 CST
  • Martin Hope
    AllisonC Como posso copiar um diretório e renomeá-lo no mesmo comando? 2017-12-22 05:28:06 +0800 CST
  • Martin Hope
    Steve Como as permissões de arquivo funcionam para o usuário "root"? 2017-12-22 02:46:01 +0800 CST
  • Martin Hope
    Bagas Sanjaya Por que o Linux usa LF como caractere de nova linha? 2017-12-20 05:48:21 +0800 CST
  • Martin Hope
    Cbhihe Altere o editor padrão para vim para _ sudo systemctl edit [unit-file] _ 2017-12-03 10:11:38 +0800 CST
  • Martin Hope
    showkey Como baixar o pacote não instalá-lo com o comando apt-get? 2017-12-03 02:15:02 +0800 CST
  • Martin Hope
    youxiao Por que os diretórios /home, /usr, /var, etc. têm o mesmo número de inode (2)? 2017-12-02 05:33:41 +0800 CST
  • Martin Hope
    user223600 gpg — o comando list-keys gera uid [ desconhecido ] depois de importar a chave privada para uma instalação limpa 2017-11-26 18:26:02 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

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