EnglishFrenchSpanish

Ad


OnWorks favicon

hfind - Online in the Cloud

Run hfind in OnWorks free hosting provider over Ubuntu Online, Fedora Online, Windows online emulator or MAC OS online emulator

This is the command hfind that can be run in the OnWorks free hosting provider using one of our multiple free online workstations such as Ubuntu Online, Fedora Online, Windows online emulator or MAC OS online emulator

PROGRAM:

NAME


hfind - Lookup a hash value in a hash database

SYNOPSIS


hfind [-i db_type ] [-f lookup_file ] [-eq] db_file [hashes]

DESCRIPTION


hfind looks up hash values in a database using a binary search algorithm. This allows one
to easily create a hash database and identify if a file is known or not. It works with
the NIST National Software Reference Library (NSRL) and the output of 'md5sum'.

Before the database can be used by 'hfind', an index file must be created with the '-i'
option.

This tool is needed for efficiency. Most text-based databases do not have fixed length
entries and are sometimes not sorted. The hfind tool will create an index file that is
sorted and has fixed-length entries. This allows for fast lookups using a binary search
algorithm instead of a linear search such as 'grep'.

ARGUMENTS


-i db_type
Create an index file for the database. This step must be done before a lookup can
be performed. The 'db_type' argument specifies the database type (i.e. nsrl-md5 or
md5sum). See section below.

-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.

-e Extended mode. Additional information besides just the name is printed. (Does not
apply for all hash database types).

-q Quick mode. Instead of displaying the corresponding information with the hash,
just display 0 if the hash was not found and 1 if it was. If this flag is used,
then only one hash can be given at a time.

-V Display version

db_file
The location of the hash database file.

[hashes]
The hashes to lookup. If they are not supplied on the command line, STDIN is used.
If index files exist for both SHA-1 and MD5 hashes, then both types of hashes can
be given at runtime.

INDEX FILE


hfind uses an index file to perform a binary search for a hash value. This is much faster
than using 'grep', which will do a linear search. Before a 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 of the NIST NSRL results in 'NSRLFile.txt-md5.idx' and
the SHA-1 index results 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 of the corresponding entry in the original
file. So, when a hash is found in the index, the offset is recorded and then 'hfind'
seeks to 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 is sorted 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) = 76b1f4de1522c20b67acc132937cf82e

and

76b1f4de1522c20b67acc132937cf82e test.txt

EXAMPLES


To create an MD5 index file for NIST NSRL:

# hfind -i nsrl-md5 /usr/local/hash/nsrl/NSRLFile.txt

To lookup a value in the NSRL:

# hfind /usr/local/hash/nsrl/NSRLFile.txt 76b1f4de1522c20b67acc132937cf82e

76b1f4de1522c20b67acc132937cf82e Hash Not Found

You 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.cpp

To 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.md5

To look entries up, the following will work:

# hfind system.md5 76b1f4de1522c20b67acc132937cf82e

76b1f4de1522c20b67acc132937cf82e Hash Not Found

or

# md5sum -q /bin/* | hfind system.md5

928682269cd3edb1acdf9a7f7e606ff2 /bin/bash

<...>

or

# md5sum -q /bin/* > bin.md5

# hfind -f bin.md5 system.md5

928682269cd3edb1acdf9a7f7e606ff2 /bin/bash

<...>

Use hfind online using onworks.net services


Free Servers & Workstations

Download Windows & Linux apps

  • 1
    VASSAL Engine
    VASSAL Engine
    VASSAL is a game engine for creating
    electronic versions of traditional board
    and card games. It provides support for
    game piece rendering and interaction,
    and...
    Download VASSAL Engine
  • 2
    OpenPDF - Fork of iText
    OpenPDF - Fork of iText
    OpenPDF is a Java library for creating
    and editing PDF files with a LGPL and
    MPL open source license. OpenPDF is the
    LGPL/MPL open source successor of iText,
    a...
    Download OpenPDF - Fork of iText
  • 3
    SAGA GIS
    SAGA GIS
    SAGA - System for Automated
    Geoscientific Analyses - is a Geographic
    Information System (GIS) software with
    immense capabilities for geodata
    processing and ana...
    Download SAGA GIS
  • 4
    Toolbox for Java/JTOpen
    Toolbox for Java/JTOpen
    The IBM Toolbox for Java / JTOpen is a
    library of Java classes supporting the
    client/server and internet programming
    models to a system running OS/400,
    i5/OS, o...
    Download Toolbox for Java/JTOpen
  • 5
    D3.js
    D3.js
    D3.js (or D3 for Data-Driven Documents)
    is a JavaScript library that allows you
    to produce dynamic, interactive data
    visualizations in web browsers. With D3
    you...
    Download D3.js
  • 6
    Shadowsocks
    Shadowsocks
    A fast tunnel proxy that helps you
    bypass firewalls This is an application
    that can also be fetched from
    https://sourceforge.net/projects/shadowsocksgui/.
    It ha...
    Download Shadowsocks
  • More »

Linux commands

Ad