vários utilitários checksums precedem o hash com barra invertida

2

O que está acontecendo aqui? Uma barra invertida em um nome de diretório e / ou nome de arquivo parece causar vários utilitários de soma de verificação para relatar o hash precedido por uma barra invertida.

Observe que o coreutil wc não se comporta dessa maneira.

Comportamento como esperado:

#ppd# ls -1a
.
..
#ppd# mkdir a\b
#ppd# ls -1
a\b
#ppd# for i in 1 2 3; do echo $i > a\b/c$i; done

#ppd# ls -1 a\b/c*
a\b/c1
a\b/c2
a\b/c3

#ppd# cat a\b/c*
1
2
3

#ppd# wc --version
wc (GNU coreutils) 8.13
#pre# wc a\b/c*
1 1 2 a\b/c1
1 1 2 a\b/c2
1 1 2 a\b/c3

#ppd# cd a\b/

#ppd# md5sum --version
md5sum (GNU coreutils) 8.13

#ppd# md5sum c*
b026324c6904b2a9cb4b88d6d61c81d1  c1
26ab0db90d72e28ad0ba1e22ee510510  c2
6d7fce9fee471194aa8b5b6e47267f03  c3

Agora, para o comportamento estranho:

#ppd# pwd
/home/abe/tdir/a\b

#ppd# md5sum ../a\b/c*
\b026324c6904b2a9cb4b88d6d61c81d1  ../a\b/c1
ab0db90d72e28ad0ba1e22ee510510  ../a\b/c2
d7fce9fee471194aa8b5b6e47267f03  ../a\b/c3

#ppd# cd ..

#ppd# md5sum a\b/c*
\b026324c6904b2a9cb4b88d6d61c81d1  a\b/c1
ab0db90d72e28ad0ba1e22ee510510  a\b/c2
d7fce9fee471194aa8b5b6e47267f03  a\b/c3

#ppd# sha1sum a\b/c*
\e5fa44f2b31c1fb553b6021e7360d07d5d91ff5e  a\b/c1
48d8798a4380162d4b56f9b452e2f6f9e24e7a  a\b/c2
\a3db5c13ff90a36963278c6a39e4ee3c22e2a436  a\b/c3

#ppd# sha256sum a\b/c*
55a46b19d348dc2f57c046f8ef63d4538ebb936000f3c9ee954a27460dd865  a\b/c1
c234e5e8472b6ac51c1ae1cab3fe06fad053beb8ebfd8977b010655bfdd3c3  a\b/c2
21cfccd5913f0a63fec40a6ffd44ea64f9dc135c66634ba001d10bcf4302a2  a\b/c3

Barra invertida no nome do arquivo:

#ppd# echo "4" > a\b/c\4
#ppd# ls -1 a\b/*
a\b/c1
a\b/c2
a\b/c3
a\b/c

#ppd# md5sum a\b/*
\b026324c6904b2a9cb4b88d6d61c81d1  a\b/c1
ab0db90d72e28ad0ba1e22ee510510  a\b/c2
d7fce9fee471194aa8b5b6e47267f03  a\b/c3
a24b70a0b376535542b996af517398  a\b/c\4

#ppd# cd a\b/
#ppd# md5sum *
b026324c6904b2a9cb4b88d6d61c81d1  c1
26ab0db90d72e28ad0ba1e22ee510510  c2
6d7fce9fee471194aa8b5b6e47267f03  c3
a24b70a0b376535542b996af517398  c\4

Eu descobri o acima ao armazenar os hashes em xattrs como ss=md5sum <filename>; setfattr -n user.cksm -v ${ss:0:32} . Aqui estão alguns dos caracteres conforme relatados por getfattr -n user.cksm.md5 (a primeira linha é apenas para ajudar na contagem dos caracteres, que deve ser o número 32 para um hash md5:

#              123456789 123456789 123456789 12
user.cksm.md5="be28d5286d9c719a904550f41593d"
user.cksm.md5="a4e9e6958c9d5762dcf090871e44bf"
user.cksm.md5="#f39b8c4dc110178505c089cba7986"
user.cksm.md5="\ebf1b8f8054d21c78f2a699776f84a0"
user.cksm.md5="+c2769ebdd2ce3a8355395d2129051"
user.cksm.md5="/9ac5b68efea0e9f02c917503cbb3e"
    
por Jeff 02.10.2016 / 03:34

1 resposta

1

(moveu a auto-resposta fora da questão)

De acordo com esta resposta para outra questão , a resposta é para a questão presente é rtfm:

NOTE: The GNU sha digests documentation reference the md5sum digest documentation

For each file, ‘md5sum’ outputs by default, the MD5 checksum, a space, a flag indicating binary or text input mode, and the file name. Binary mode is indicated with ‘*’, text mode with ‘ ’ (space). Binary mode is the default on systems where it’s significant, otherwise text mode is the default. If file contains a backslash or newline, the line is started with a backslash, and each problematic character in the file name is escaped with a backslash, making the output unambiguous even in the presence of arbitrary file names. If file is omitted or specified as ‘-’, standard input is read.

    
por 13.04.2017 / 14:36

Tags