LibWhisker is the Perl module Nikto
relies on for its core functionality. At the time of this writing,
the current Nikto version ships with LibWhisker 1.7. In general you
will not need to use more than a handful of LibWhisker routines. Keep
in mind they are all available and have very powerful features, such
as crawling, NT Lan Man (NTLM) authentication support, hashing, and
encoding. The names of the 69 exported routines are detailed here to
help you understand the kind of functionality they provide. You can
generate a very detailed manual of these routines from LibWhisker
itself. To do this, uncompress LibWhisker and run the following
commands:
$cd libwhisker-1.8/scripts/
$perl func2html.pl < ../LW.pm > LW.pod.htm
Here are the
routines
LibWhisker exports:
In addition to the LibWhisker routines, plug-in developers can also
use
routines
provided by the nikto_core
plug-in. Many of these
routines are meant for one-time use or for internal use only. Here
are the common routines from LibWhisker and
nikto_core
that are frequently used by the
existing plug-ins, along with a brief description of each:
-
fetch
This takes two
parameters, and an optional third parameter. The first parameter is
the full path of a file that is to be requested. The second parameter
is the HTTP method to use for the request. The optional third
parameter is any POST
data for the request. The
routine makes an HTTP request and returns two scalars. The first
returned value is the response code number and the second is the data
returned. This routine will make the request using the LibWhisker
parameters set by Nikto, so the host that is currently being scanned
is where the request will be sent.
-
parse_csv
This takes a single string of comma-separated values as a parameter
and returns an array of those items without the commas.
-
nprint
This takes one required parameter, and one optional parameter. The
required parameter is the string to send to output (output depends on
what was specified on the command line). The optional parameter
prints only if Nikto is run in verbose or debug mode.
-
char_escape
This takes one string parameter, escapes all nonalphanumeric
characters in it with the \
character before them,
and returns the result.
If you need a higher level of control over the
HTTP requests, you can use the
LibWhisker routines. The most commonly used routines for plug-ins are
summarized next. The LibWhisker request hash
$request{'whisker'}
has many values you can set to
control the request. These should be returned to their original
values if they are changed within a plug-in. See the
nikto_headers
plug-in as an example of how to do
this correctly.
-
LW::http_do_request
This takes two parameters: a request hash and a response hash that
will be populated accordingly. An optional third parameter is a
LibWhisker configs hash. The routine does the work of the actual HTTP
request. It returns 0
on success and a nonzero
value on error.
-
LW::http_fixup_request
This makes sure the request conforms to the HTTP standard. It should
be called immediately prior to
http_do_request
. It takes the request hash as the only
parameter.
-
LW::http_reset
This resets internal LibWhisker caches and closes existing
connections.
-
LW::utils_get_dir
This takes in a URI as a parameter and returns the base directory,
similar to the dirname
command on Linux systems.
-
LW::utils_normalize_uri
This takes one parameter and corrects any ./
or
../
sequences to get a final, absolute URL.
-
LW::auth_set_header
This sets authorization information in the request hash. It takes
four required parameters and one optional parameter. The first
parameter is either ntlm
or
basic
, the second is the request hash, the third
and fourth are the username and password, and the optional parameter
is the domain (for ntlm
auth
).