Posts: 803
Threads: 135
Joined: Feb 2011
11-20-2018, 08:43 PM
(This post was last modified: 11-20-2018, 08:43 PM by Mem5.)
Hi,
I notice a double '*' in the
example Winzip hash:
$zip2$*0*3*0*b5d2b7bf57ad5e86a55c400509c672bd*d218*0
**ca3d736d03a34165cfa9*$/zip2$
When I extract some hashes from zip file, I have some (huge) data betwen those 2.
I suppose that the data between those red 2 '*' are useless for cracking purposes?
Thank you.
Posts: 193
Threads: 0
Joined: Nov 2017
11-21-2018, 10:59 AM
(This post was last modified: 11-21-2018, 11:00 AM by DanielG.)
Code:
filename:$zip2$*Ty*Mo*Ma*Sa*Va*Le*DF*Au*$/zip2$
Ty = type (0) and ignored.
Mo = mode (1 2 3 for 128/192/256 bit)
Ma = magic (file magic). This is reservered for now. See pkzip_fmt_plug.c or zip2john.c for information.
For now, this must be a '0'
Sa = salt(hex). 8, 12 or 16 bytes of salt (depends on mode)
Va = Verification bytes(hex) (2 byte quick checker)
Le = real compr len (hex) length of compressed/encrypted data (field DF)
DF = compressed data DF can be Le*2 hex bytes, and if so, then it is the ENTIRE file blob written 'inline'.
However, if the data blob is too long, then a .zip ZIPDATA_FILE_PTR_RECORD structure will be the 'contents' of DF
Au = Authentication code (hex) a 10 byte hex value that is the hmac-sha1 of data over DF. This is the binary() value
ZIPDATA_FILE_PTR_RECORD (this can be the 'DF' of this above hash line).
*ZFILE*Fn*Oh*Ob* (Note, the leading and trailing * are the * that 'wrap' the DF object.
ZFILE This is the literal string ZFILE
Fn This is the name of the .zip file. NOTE the user will need to keep the .zip file in proper locations (same as
was seen when running zip2john. If the file is removed, this hash line will no longer be valid.
Oh Offset to the zip central header record for this blob.
Ob Offset to the start of the blob data
From
https://github.com/magnumripper/JohnTheR...zip2john.c, the field DF looks important, but in the example I think it is empty because "Le = real compr len (hex) length of compressed/encrypted data (field DF)" is zero.
Posts: 803
Threads: 135
Joined: Feb 2011
11-21-2018, 11:36 AM
(This post was last modified: 11-21-2018, 11:37 AM by Mem5.)
Right,
Quote:DF = compressed data DF can be Le*2 hex bytes, and if so, then it is the ENTIRE file blob written 'inline'.
So if your zip file is 100 Mb, the hash will be huge for nothing.
After testing on multiple zip files, I can say that "DF" part of the hash is useless for hashcat to find the password.