/usr/bin/lwp-dump is in libwww-perl 6.08-1.
This file is owned by root:root, with mode 0o755.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 | #!/usr/bin/perl -w
eval 'exec /usr/bin/perl -w -S $0 ${1+"$@"}'
if 0; # not running under some shell
use strict;
use LWP::UserAgent ();
use Getopt::Long qw(GetOptions);
use Encode;
use Encode::Locale;
my $VERSION = "6.06";
GetOptions(\my %opt,
'parse-head',
'max-length=n',
'keep-client-headers',
'method=s',
'agent=s',
'request',
) || usage();
my $url = shift || usage();
@ARGV && usage();
sub usage {
(my $progname = $0) =~ s,.*/,,;
die <<"EOT";
Usage: $progname [options] <url>
Recognized options are:
--agent <str>
--keep-client-headers
--max-length <n>
--method <str>
--parse-head
--request
EOT
}
my $ua = LWP::UserAgent->new(
parse_head => $opt{'parse-head'} || 0,
keep_alive => 1,
env_proxy => 1,
agent => $opt{agent} || "lwp-dump/$VERSION ",
);
my $req = HTTP::Request->new($opt{method} || 'GET' => decode(locale => $url));
my $res = $ua->simple_request($req);
$res->remove_header(grep /^Client-/, $res->header_field_names)
unless $opt{'keep-client-headers'} or
($res->header("Client-Warning") || "") eq "Internal response";
if ($opt{request}) {
$res->request->dump;
print "\n";
}
$res->dump(maxlength => $opt{'max-length'});
__END__
=head1 NAME
lwp-dump - See what headers and content is returned for a URL
=head1 SYNOPSIS
B<lwp-dump> [ I<options> ] I<URL>
=head1 DESCRIPTION
The B<lwp-dump> program will get the resource identified by the URL and then
dump the response object to STDOUT. This will display the headers returned and
the initial part of the content, escaped so that it's safe to display even
binary content. The escapes syntax used is the same as for Perl's double
quoted strings. If there is no content the string "(no content)" is shown in
its place.
The following options are recognized:
=over
=item B<--agent> I<str>
Override the user agent string passed to the server.
=item B<--keep-client-headers>
LWP internally generate various C<Client-*> headers that are stripped by
B<lwp-dump> in order to show the headers exactly as the server provided them.
This option will suppress this.
=item B<--max-length> I<n>
How much of the content to show. The default is 512. Set this
to 0 for unlimited.
If the content is longer then the string is chopped at the
limit and the string "...\n(### more bytes not shown)"
appended.
=item B<--method> I<str>
Use the given method for the request instead of the default "GET".
=item B<--parse-head>
By default B<lwp-dump> will not try to initialize headers by looking at the
head section of HTML documents. This option enables this. This corresponds to
L<LWP::UserAgent/"parse_head">.
=item B<--request>
Also dump the request sent.
=back
=head1 SEE ALSO
L<lwp-request>, L<LWP>, L<HTTP::Message/"dump">
|