📄 hfind.1
字号:
.TH HFIND 1 .SH NAMEhfind \- Lookup a hash value in a hash database.SH SYNOPSIS.B hfind [-i.I db_type.B ] [-f.I lookup_file.B ] [-eq] .I db_file [hashes].SH DESCRIPTION.B hfindlooks up hash values in a database using a binary search algorithm. This allows one to easily create a hash database and identify if a fileis known or not. It works with the NIST National Software ReferenceLibrary (NSRL) and the output of 'md5sum'. Before the database can be used by 'hfind', an index file must be createdwith the '-i' option. This tool is needed for efficiency. Most text-based databases donot have fixed length entries and are sometimes not sorted. Thehfind tool will create an index file that is sorted and hasfixed-length entries. This allows for fast lookups using a binarysearch algorithm instead of a linear search such as 'grep'..SH ARGUMENTS.IP "-i db_type"Create an index file for the database. This step must be done beforea lookup can be performed. The 'db_type' argument specifies the database type (i.e. nsrl-md5 or md5sum). See section below..IP "-f lookup_file"Specify the location of a file that contains one hash value per line. These hashes will be looked up in the database. .IP -eExtended mode. Additional information besides just the name is printed.(Does not apply for all hash database types)..IP -qQuick mode. Instead of displaying the corresponding information withthe hash, just display 0 if the hash was not found and 1 if it was. Ifthis flag is used, then only one hash can be given at a time. .IP -VDisplay version.IP db_fileThe location of the hash database file. .IP [hashes]The hashes to lookup. If they are not supplied on the command line, STDINis used. If index files exist for both SHA-1 and MD5 hashes, then bothtypes of hashes can be given at runtime. .SH INDEX FILE.B hfind uses an index file to perform a binary search for a hash value. Thisis much faster than using 'grep', which will do a linear search. Beforea hash database is used, a corresponding index file must be created.This is done with the '-i' option to hfind. The resulting index file will be named based on the database file name.The name will have the original name following by the hash type (sha1 or md5) followed by '.idx'. For example, creating an MD5 hash index ofthe NIST NSRL results in 'NSRLFile.txt-md5.idx' and the SHA-1 indexresults in 'NSRLFile.txt-sha1.idx'. The file has two columns. Each entry is sorted by the first column,which is the hash value. The second column has the byte offset ofthe corresponding entry in the original file. So, when a hash isfound in the index, the offset is recorded and then 'hfind' seeksto the entry in the original database.The following input types are valid. For NSRL, 'nsrl-md5' and\'nsrl-sha1' can be used. The difference is which hash value the index issorted by. The 'md5sum' value can also be used to sort and index "home made"databases. 'hfind' can take data in both common formats: MD5 (test.txt) = 76b1f4de1522c20b67acc132937cf82eand 76b1f4de1522c20b67acc132937cf82e test.txt.SH EXAMPLESTo create an MD5 index file for NIST NSRL: # hfind -i nsrl-md5 /usr/local/hash/nsrl/NSRLFile.txtTo lookup a value in the NSRL: # hfind /usr/local/hash/nsrl/NSRLFile.txt 76b1f4de1522c20b67acc132937cf82e 76b1f4de1522c20b67acc132937cf82e Hash Not FoundYou can even do both SHA-1 and MD5 if you want: # hfind -i nsrl-sha1 /usr/local/hash/nsrl/NSRLFile.txt # hfind /usr/local/hash/nsrl/NSRLFile.txt 76b1f4de1522c20b67acc132937cf82e 80001A80B3F1B80076B297CEE8805AAA04E1B5BA 76b1f4de1522c20b67acc132937cf82e Hash Not Found 80001A80B3F1B80076B297CEE8805AAA04E1B5BA thrdcore.cppTo make a database of critical binaries of a trusted system, use 'md5sum': # md5sum /bin/* /sbin/* /usr/bin/* /usr/bin/* /usr/local/bin/* /usr/local/sbin/* > system.md5 # hfind -i md5sum system.md5To look entries up, the following will work: # hfind system.md5 76b1f4de1522c20b67acc132937cf82e 76b1f4de1522c20b67acc132937cf82e Hash Not Foundor # md5sum -q /bin/* | hfind system.md5 928682269cd3edb1acdf9a7f7e606ff2 /bin/bash <...>or # md5sum -q /bin/* > bin.md5 # hfind -f bin.md5 system.md5 928682269cd3edb1acdf9a7f7e606ff2 /bin/bash <...>.SH REQUIREMENTShfind needs the UNIX sorter program located in /usr/bin/.The NIST National Software Reference Library (NSRL) can be found atwww.nsrl.nist.gov..SH LICENSEDistributed under the Common Public License, found in the.I cpl1.0.txtfile in the The Sleuth Kit licenses directory..SH AUTHORBrian Carrier <carrier at sleuthkit dot org>Send documentation updates to <doc-updates at sleuthkit dot org>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -