¿Cómo verifico el hash SHA1 de un archivo?

228

¿Cómo verifico el hash SHA1 de un archivo?

Lincity
fuente
66
agregando esta nota a quien corresponda: SHA-1 ahora está comprometido , demostrado por una investigación conjunta de Google-CWI . TL; DR No lo use en ningún lugar que tenga ningún valor.
kmonsoor
2
TL; DR, ¿qué más usar?
Benjamin Eckstein

Respuestas:

263

sha1sum

Imprima o verifique las sumas de verificación SHA1 (160 bits). Sin FILE, o cuando FILE es -, lea la entrada estándar.

sha1sum {file}

Si desea enviar el archivo junto con su salida sha1sum, redirija la salida a un archivo:

sha1sum {file} > {file}.sha1

Envíe ambos archivos y la otra parte puede hacer un ...

sha1sum -c {file}.sha1

Debería mostrar OKsi sha1es correcto.

Rinzwind
fuente
3
¡Excelente! Pero, ¿cómo se ejecuta sha1sum -ccuando {file}.sha1contiene solo el hash y ningún nombre de archivo (que a menudo se descarga desde varios rincones de Internet)? Se me ocurrió for f in *.sha1; do echo "$(cat $f) ${f/.sha1/}"; done | sha1sum -c(nota doble espacio), pero esto debe ser mucho más simple.
Piotr Findeisen
3
o shasum- el SHA predeterminado es (si estoy en lo correcto) SHA1. También lo configura con la -a, --algorithmopción:shasum -a 1
xealits
3
@PiotrFindeisen: el resultado de sha1sum es <hash> <full file path>que hay suficiente información para que sha1sum -c sepa qué archivo debe verificar
CrazyPenguin
1
Disculpe mi ignorancia, pero ¿por qué es tan difícil verificar la suma de un archivo? ¿No podríamos simplemente hacer sha1sum <file_path> <the_expected_hash> ?
Romain Vincent
63

Sin crear un archivo local:

$ sha1sum filename

8dd10000eb1b768800000e1d2fe1c3100005d2dc *filename

Para verificar, vaya al directorio que contiene filenamey ejecute este comando:

echo "8dd10000eb1b768800000e1d2fe1c3100005d2dc *filename" | sha1sum -c -
usuario139320
fuente
44
Gracias, aunque no creo que debas tener el * allí. Aquí hay un ejemplo concreto: echo 'b78bb50bdac5ec8c108f34104f788e214ac23635 raspbian.zip' | sha1sum -c - que verificará un nombre de archivo raspbian.zip en el directorio actual.
Lucas,
1
Esta debería ser la respuesta aceptada. Crear un archivo es un intermedio innecesario.
Joel B
En caso de que alguien llegue aquí y esté en una Mac, hay dos espacios entre el nombre de archivo y la salida de shasum a partir de OSX 10.13.3. Cuando usé solo uno, recibí un error de formato incorrecto para shasum -c
ae0709
21

Es muy sencillo.

Navegue a la terminal y escriba:

sha1sum  filename

para confirmar un uso de hash sha1:

sha1sum -c filename
Amith KK
fuente
1
¿Qué significa confirmar el hash sha1?
Alexander Mills
6

Para aquellos que están en mac y no tienen coreutils / sha1sum instalado.

openssl sha1 <file>

Ejemplo:

$ openssl sha1 `mktemp`
SHA1(/tmp/tmp.jkyfOWma3t)= da39a3ee5e6b4b0d3255bfef95601890afd80709
navigaid
fuente
esto es askubunutu, por lo que estar en una Mac estaría fuera de tema;) pero esto también debería funcionar en ubuntu, así que +1
Jeff Puckett
4

¿De qué están hablando? Sí, entiendo el concepto detrás de sha1sum, pero la información anterior es confusa para decir lo mejor. Primero, Ubuntu no parece tener archivos sha1sum, solo cadenas en una página web como esta para 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 la integridad de un .iso descargado, uno abre el programa de terminal, hace "Descargas de CD", luego sha1sum. Después de un momento, el terminal producirá un hash como

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

Luego, tenemos que ir a la página web y comparar las cadenas para verificar que la verificación funciona. No es tan fácil como podría ser.

Dave

Dave
fuente
1

Pitón

Python tiene una excelente hashlibbiblioteca, que permite calcular múltiples hashsums, incluidos sha1. Aquí hay un script simple que puede hacer el trabajo:

#!/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()

Prueba de funcionamiento:

Con un solo archivo:

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

Con 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
fuente