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