Como verifico o hash SHA1 de um arquivo?

228

Como verifico o hash SHA1 de um arquivo?

Lincity
fonte
6
adicionando esta nota a quem possa interessar: o SHA-1 agora está comprometido , comprovado por uma pesquisa conjunta Google-CWI . TL; DR Não use em qualquer lugar que possua qualquer valor.
kmonsoor 23/02
2
TL; DR o que mais usar ???
Benjamin Eckstein

Respostas:

263

sha1sum

Imprima ou verifique as somas de verificação SHA1 (160 bits). Sem FILE, ou quando FILE for -, leia a entrada padrão.

sha1sum {file}

Se você deseja enviar o arquivo junto com sua saída sha1sum, redirecione a saída para um arquivo:

sha1sum {file} > {file}.sha1

Envie os dois arquivos e a outra parte pode fazer uma ...

sha1sum -c {file}.sha1

Deve mostrar OKse o sha1está correto.

Rinzwind
fonte
3
Ótimo! Mas como você executa sha1sum -cquando {file}.sha1contém apenas o hash e nenhum nome de arquivo (tantas vezes para ser baixado de vários cantos da Internet)? Eu vim com for f in *.sha1; do echo "$(cat $f) ${f/.sha1/}"; done | sha1sum -c(note espaço duplo), mas isso deve ser muito mais simples.
Piotr Findeisen 17/10
3
ou shasum- o SHA padrão é (se estiver correto) SHA1. Você também pode configurá-lo com a -a, --algorithmopção:shasum -a 1
xealits 23/09
3
@PiotrFindeisen - A saída do sha1sum é <hash> <full file path>assim não há informações suficientes para sha1sum -c saber qual arquivo é para verificar
CrazyPenguin
1
Perdoe minha ignorância, mas por que é tão difícil verificar uma soma de arquivos? Não poderíamos simplesmente fazer sha1sum <file_path> <the_expected_hash> ?
Romain Vincent
63

Sem criar arquivo local:

$ sha1sum filename

8dd10000eb1b768800000e1d2fe1c3100005d2dc *filename

Para verificação, vá para o diretório que contém filenamee execute este comando:

echo "8dd10000eb1b768800000e1d2fe1c3100005d2dc *filename" | sha1sum -c -
user139320
fonte
4
Obrigado, embora eu não ache que você deva ter o * lá. Aqui está um exemplo concreto: echo 'b78bb50bdac5ec8c108f34104f788e214ac23635 raspbian.zip' | sha1sum -c - Isso verificará um nome de arquivo raspbian.zip no diretório atual.
Luke
1
Essa deve ser a resposta aceita. Criar um arquivo é um intermediário desnecessário.
Joel B
Caso alguém chegue aqui e esteja em um mac, existem dois espaços entre o nome do arquivo e a saída do shasum a partir do OSX 10.13.3. Quando eu usei apenas um, eu tenho um erro de formatação incorreta para -c shasum
ae0709
21

É muito simples.

Navegue até o terminal e digite:

sha1sum  filename

para confirmar um uso de hash sha1:

sha1sum -c filename
Amith KK
fonte
1
o que confirmar o hash sha1 faz?
Alexander Mills
6

Para quem está no mac e não possui o coreutils / sha1sum instalado.

openssl sha1 <file>

Exemplo:

$ openssl sha1 `mktemp`
SHA1(/tmp/tmp.jkyfOWma3t)= da39a3ee5e6b4b0d3255bfef95601890afd80709
navigaid
fonte
este é askubunutu, então estar em um Mac seria off-topic); mas isso deve funcionar no Ubuntu também, então +1
Jeff Puckett
4

Sobre o que vocês estão falando? Sim, entendo o conceito por trás do sha1sum, mas as informações acima são confusas para dizer o melhor. Primeiro, o Ubuntu não parece ter arquivos sha1sum - apenas strings em uma página da Web como esta para o Mate 16.04 Beta 1:

bfba577970d573e0ba5095fbb72787de97f88b4b *ubuntu-mate-16.04-beta1-desktop-amd64.iso
efcbbc70b10173cea203df30396d0848ba8fa0d8 *ubuntu-mate-16.04-beta1-desktop-i386.iso
8563fec4d66bce851b0800f5ac746f38e4041a6a *ubuntu-mate-16.04-beta1-desktop-powerpc.iso

Para verificar a integridade de um .iso baixado, é aberto o programa do terminal, "cd Downloads" e, em seguida, sha1sum. Depois de um tempo, o terminal produzirá um hash como

efcbbc70b10173cea203df30396d0848ba8fa0d8  ubuntu-mate-16.04-beta1-desktop-i386.iso

Em seguida, temos que ir para a página da web e comparar as strings para verificar se a verificação funciona. Não é tão fácil quanto poderia ser.

Dave,

Dave
fonte
1

Pitão

O Python possui uma excelente hashlibbiblioteca, que permite calcular vários hashsums, inclusive sha1. Aqui está um script simples que pode fazer o trabalho:

#!/usr/bin/env python3
import sys
import hashlib
import os
from collections import OrderedDict as od

def get_hashsums(file_path):
    hash_sums = od()
    hash_sums['md5sum'] = hashlib.md5()
    hash_sums['sha1sum'] = hashlib.sha1()
    hash_sums['sha224sum'] = hashlib.sha224()
    hash_sums['sha256sum'] = hashlib.sha256()
    hash_sums['sha384sum'] = hashlib.sha384()
    hash_sums['sha512sum'] = hashlib.sha512()

    with open(file_path, 'rb') as fd:
        data_chunk = fd.read(1024)
        while data_chunk:
              for hashsum in hash_sums.keys():
                  hash_sums[hashsum].update(data_chunk)
              data_chunk = fd.read(1024)

    results = od()
    for key,value in hash_sums.items():
         results[key] = value.hexdigest()         
    return results



def main():
    for path in sys.argv[1:]:
        print(">>> ",path)
        for key,value in get_hashsums(path).items():
            print(key,value)

if __name__ == '__main__': main()

Execução de teste:

Com um único arquivo:

$ ./hash_sums.py /etc/passwd                                                                                                                         
>>>  /etc/passwd
md5sum ce5f247e016ba2bb92049fc86158376a
sha1sum b8abadf4618b09bd3eebb6064fc2df5b90e5ae03
sha224sum 044579d46e0d969a860602216ea4764465e5618ed714109cf782ff50
sha256sum 53f2ff8997625c958f77aef034f9c96d9fcfc8bcb4bb8a96fd8ac89a5ed5adf6
sha384sum b84b6cafa178147614e6b7903e1b7a342e09d95e3101e55c6a3b5b093a22190f2d367c69b1ee12b1ec59726337a40e9c
sha512sum edacca8237d3be5095f392c9d347dce3a5249c79d09f9b99a055b796edd74541b4529c499ff0e4f25e817b702c206073bfe5b0fccae6773680c79ea1e0efa9e2

Com glob:

$ ./hash_sums.py *                                                                                                                                   
>>>  3-4-placement.py
md5sum a81dd2a6eb122176204cacd92d76d08c
sha1sum 4972f8cf08701cdfc6308def05d3ec2eedfcdd9a
sha224sum 32c4dad60f59584ba39ce73c1a1c96d4da36ee6fe3fd291145692b2b
sha256sum 7460ebf8736b0d6e7be8a1025743d0498871c7013cf5ad4463366fd95fe7576a
sha384sum 77de28b4b185d9a5d7d49aef0aad432d37145b914557dc6ecf3e6cdcbd6cd4a1999d717c027489ac99751f066050199b
sha512sum 7bf6a8059601c72e1278e321f225fef82f12a7bad73e1e8c5c43c1fcbdc2243934bf7d1ad07534bdbf10e2dd9ea9265e1debcbdf6603bec24ede665d2f651cf5
>>>  SHA256SUMS
md5sum 3c37318d45676c1db2598aa817b37679
sha1sum 8338b8ae5f749551d131dc28aebb80a2b125d651
sha224sum e89ad392f10a77b0940792a03470f3a23df2f2df9c8b6a91a1c496e0
sha256sum dd4a53f7da270f3b6ab691841ca911a231e20af53d7fabc5a39059b9dbdb036d
sha384sum aadfb55856730eb5b7e4192111bfb8fc4c022396a5809cb37fdd8e8b6ac8dbb3b7e462266cde2b34f90d7015fb42fe2b
sha512sum baba0ed86ad781daffb5905512459e353b7ca7da7b04cf67a26cfb320906041da2d4bc73673926aab7c98869f25bc2fd6ea0116c21c40c07188e6dcbbba3dbcf
>>>  answer.md
md5sum b6111facdba5978e6cf3a200706ba6fd
sha1sum 5c2eb00c4c0c4799d4457d3a84eea283a3a0d249
sha224sum 7172f877ab579e1ee845c723e0d42ff3acb96859cc43a56aebc39f59
sha256sum dc6ac7365f680e98b9f1279d2e22ed21b9b82c988b99b0facd5e8a98ff50ddd6
sha384sum 5082b3b62d677c5b1b8938f871da16c595be16a540bd76bc9c25ea6572dc9020f236237ec310cfa78fdaa1d0c0a51b0f
sha512sum 81f21316ab6c5a4038cdcde528766e620988a0ccf53bf2e9932399f4534c070468949a5a43ea68629c07e622404574e46bb20cf60c51da4e2a7a44a1df71d920
Sergiy Kolodyazhnyy
fonte