Como usar openssl e md5sum para verificar integridade de arquivos
md5sum arquivo.tar > arquivo.tar.md5Verificar o hash
md5sum -c arquivo.tar.md5A verificação do hash, usa o seguinte formato para verificação
534a15536aa0152e178361983c678cc0 arquivo.tar.md5O motivo desta dica, não é necessariamente sobre o md5sum, mas porque essa ferramenta não está disponível nativamente no solaris, onde uso o openssl. No solaris, para criar o hash, uso openssl da seguinte maneira
openssl dgst -md5 <arquivo>Que gera um resultado da seguinte maneira
$ openssl dgst -md5 list.conf MD5(list.conf)= e5c8ebe8e2113448fd318328cf5ca582Que é diferente do md5sum, então não é possível realizar a verificação de integridade usando checksums md5. Por isso criei um script bash, para solaris que faz uma tarefa semelhante do utilitário md5sum.
Download do script bash md5sum_solaris.sh
Dependências: openssl, awk, sed
O código é o seguinte:
#!/bin/bash if [ "$1" ] ; then if [ $1 = '-c' ] && [ $2"x" != 'x' ] ; then shift cat $1 | while read hash_line do hash_value=`echo $hash_line | awk '{print $1}'` filename=`echo $hash_line | awk '{print $2}'` echo -n $filename": " if [ -f "$filename" ] ; then hash_var=`openssl dgst -md5 $filename | awk '{print $2}'` ; if [ $hash_var == $hash_value ] ; then echo "OK" else echo "FAILED" fi else echo "FAILED: No such file or directory" fi done else openssl dgst -md5 $* | sed 's/[\(\)=]//g;s/MD5//g' | awk '{print $2" "$1}' fi else echo "Usage: $0 -c hashs.md5 to verify checksums $0 <file> to create checksums " fi
Deixe um comentário