2009-09-10 07:15:01 +08:00
|
|
|
#!/usr/bin/perl -w
|
|
|
|
|
|
|
|
# Simple command line web client.
|
|
|
|
# Initially loosely based on examples from the perlipc manpage.
|
|
|
|
#
|
2009-09-10 18:08:17 +08:00
|
|
|
# Copyright (C) 2009 Michael Adam <obnox@samba.org>
|
2009-09-10 07:15:01 +08:00
|
|
|
#
|
2009-09-10 18:08:17 +08:00
|
|
|
# This program is free software; you can redistribute it and/or modify it
|
|
|
|
# under the terms of the GNU General Public License as published by the Free
|
|
|
|
# Software Foundation; either version 2 of the License, or (at your option)
|
|
|
|
# any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
|
|
# more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License along with
|
|
|
|
# this program; if not, see <http://www.gnu.org/licenses/>.
|
2009-09-10 07:15:01 +08:00
|
|
|
|
|
|
|
use strict;
|
|
|
|
|
|
|
|
use IO::Socket;
|
2009-09-17 04:27:57 +08:00
|
|
|
use Getopt::Long;
|
|
|
|
use Pod::Usage;
|
2009-09-10 07:15:01 +08:00
|
|
|
|
|
|
|
my $EOL = "\015\012";
|
2009-09-14 19:29:27 +08:00
|
|
|
|
|
|
|
my $NAME = "Tinyproxy-Web-Client";
|
2024-06-20 16:51:29 +08:00
|
|
|
my $user_agent = "$NAME";
|
2009-09-17 04:27:57 +08:00
|
|
|
my $user_agent_header = "User-Agent: $user_agent$EOL";
|
2009-09-20 19:24:06 +08:00
|
|
|
my $http_version = "1.0";
|
2009-09-17 04:27:57 +08:00
|
|
|
my $method = "GET";
|
2009-09-17 04:34:35 +08:00
|
|
|
my $dry_run = 0;
|
2009-09-17 04:27:57 +08:00
|
|
|
my $help = 0;
|
2009-10-12 08:01:25 +08:00
|
|
|
my $entity = undef;
|
2009-09-17 04:27:57 +08:00
|
|
|
|
|
|
|
my $default_port = "80";
|
|
|
|
my $port = $default_port;
|
|
|
|
|
|
|
|
sub process_options() {
|
|
|
|
my $result = GetOptions("help|?" => \$help,
|
|
|
|
"http-version=s" => \$http_version,
|
2009-09-17 04:34:35 +08:00
|
|
|
"method=s" => \$method,
|
2009-10-12 08:01:25 +08:00
|
|
|
"dry-run" => \$dry_run,
|
|
|
|
"entity=s" => \$entity);
|
2009-09-17 04:27:57 +08:00
|
|
|
die "Error reading cmdline options! $!" unless $result;
|
|
|
|
|
|
|
|
pod2usage(1) if $help;
|
|
|
|
|
|
|
|
# some post-processing:
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-10-12 08:01:25 +08:00
|
|
|
sub build_request($$$$$$)
|
2009-09-17 04:27:57 +08:00
|
|
|
{
|
2009-10-12 08:01:25 +08:00
|
|
|
my ( $host, $port, $version, $method, $document, $entity ) = @_;
|
2009-09-17 04:27:57 +08:00
|
|
|
my $request = "";
|
|
|
|
|
|
|
|
$method = uc($method);
|
|
|
|
|
|
|
|
if ($version eq '0.9') {
|
|
|
|
if ($method ne 'GET') {
|
|
|
|
die "invalid method '$method'";
|
|
|
|
}
|
2009-09-17 06:24:21 +08:00
|
|
|
$request = "$method $document$EOL";
|
2009-09-17 04:27:57 +08:00
|
|
|
} elsif ($version eq '1.0') {
|
|
|
|
$request = "$method $document HTTP/$version$EOL"
|
2009-09-17 06:24:21 +08:00
|
|
|
. $user_agent_header;
|
2009-09-17 04:27:57 +08:00
|
|
|
} elsif ($version eq '1.1') {
|
|
|
|
$request = "$method $document HTTP/$version$EOL"
|
|
|
|
. "Host: $host" . (($port and ($port ne $default_port))?":$port":"") . "$EOL"
|
|
|
|
. $user_agent_header
|
2009-09-17 06:24:21 +08:00
|
|
|
. "Connection: close$EOL";
|
2009-09-17 04:27:57 +08:00
|
|
|
} else {
|
|
|
|
die "invalid version '$version'";
|
|
|
|
}
|
|
|
|
|
2009-09-17 06:24:21 +08:00
|
|
|
$request .= $EOL;
|
|
|
|
|
2009-10-12 08:01:25 +08:00
|
|
|
if ($entity) {
|
|
|
|
$request .= $entity;
|
|
|
|
}
|
|
|
|
|
2009-09-17 04:27:57 +08:00
|
|
|
return $request;
|
|
|
|
}
|
|
|
|
|
|
|
|
# main
|
|
|
|
|
|
|
|
process_options();
|
2009-09-10 07:15:01 +08:00
|
|
|
|
|
|
|
unless (@ARGV > 1) {
|
2009-09-17 04:27:57 +08:00
|
|
|
pod2usage(1);
|
2009-09-10 07:15:01 +08:00
|
|
|
}
|
|
|
|
|
2009-09-17 04:27:57 +08:00
|
|
|
my $hostarg = shift(@ARGV);
|
|
|
|
my $host = $hostarg;
|
2009-09-10 07:15:01 +08:00
|
|
|
|
|
|
|
if ($host =~ /^([^:]+):(.*)/) {
|
|
|
|
$port = $2;
|
|
|
|
$host = $1;
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach my $document (@ARGV) {
|
2009-10-12 08:01:25 +08:00
|
|
|
my $request = build_request($host, $port, $http_version, $method, $document, $entity);
|
2009-09-17 04:34:35 +08:00
|
|
|
if ($dry_run) {
|
|
|
|
print $request;
|
|
|
|
exit(0);
|
|
|
|
}
|
|
|
|
|
2009-09-10 07:15:01 +08:00
|
|
|
my $remote = IO::Socket::INET->new(
|
|
|
|
Proto => "tcp",
|
|
|
|
PeerAddr => $host,
|
|
|
|
PeerPort => $port,
|
|
|
|
);
|
|
|
|
unless ($remote) {
|
|
|
|
die "cannot connect to http daemon on $host (port $port)";
|
|
|
|
}
|
|
|
|
|
|
|
|
$remote->autoflush(1);
|
|
|
|
|
2009-09-17 04:34:35 +08:00
|
|
|
print $remote $request;
|
2009-09-14 19:29:27 +08:00
|
|
|
|
2020-09-13 07:33:16 +08:00
|
|
|
$_ = <$remote>;
|
|
|
|
print; # /* HTTP/1.0 400 Bad Request */
|
|
|
|
my($errn) = ($_ =~ /HTTP\/\d\.\d (\d{3})/);
|
|
|
|
|
2009-09-10 07:15:01 +08:00
|
|
|
while (<$remote>) {
|
|
|
|
print;
|
|
|
|
}
|
2009-09-14 19:29:27 +08:00
|
|
|
|
2009-09-10 07:15:01 +08:00
|
|
|
close $remote;
|
2020-09-13 07:33:16 +08:00
|
|
|
exit($errn - 399) if($errn > 399);
|
2009-09-10 07:15:01 +08:00
|
|
|
}
|
2009-09-17 04:27:57 +08:00
|
|
|
|
|
|
|
exit(0);
|
|
|
|
|
|
|
|
__END__
|
|
|
|
|
|
|
|
=head1 webclient.pl
|
|
|
|
|
|
|
|
A simple WEB client written in perl.
|
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
|
|
|
webclient.pl [options] host[:port] document [document ...]
|
|
|
|
|
|
|
|
=head1 OPTIONS
|
|
|
|
|
|
|
|
=over 8
|
|
|
|
|
|
|
|
=item B<--help>
|
|
|
|
|
|
|
|
Print a brief help message and exit.
|
|
|
|
|
|
|
|
=item B<--http-version>
|
|
|
|
|
|
|
|
Specify the HTTP protocol version to use (0.9, 1.0, 1.1). Default is 1.0.
|
|
|
|
|
|
|
|
=item B<--method>
|
|
|
|
|
|
|
|
Specify the HTTP request method ('GET', 'CONNECT', ...). Default is 'GET'.
|
|
|
|
|
2009-10-12 08:01:25 +08:00
|
|
|
=item B<--entity>
|
|
|
|
|
|
|
|
Add the provided string as entity (i.e. body) to the request.
|
|
|
|
|
2009-09-17 04:34:35 +08:00
|
|
|
=item B<--dry-run>
|
|
|
|
|
|
|
|
Don't actually connect to the server but print the request that would be sent.
|
|
|
|
|
2009-09-17 04:27:57 +08:00
|
|
|
=back
|
|
|
|
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
|
|
|
This is a basic web client. It permits to send http request messages to
|
|
|
|
web servers or web proxy servers. The result is printed as is to standard output,
|
|
|
|
including headers. This is meant as a tool for diagnosing and testing
|
|
|
|
web servers and proxy servers.
|
|
|
|
|
2009-09-17 06:25:28 +08:00
|
|
|
=head1 COPYRIGHT
|
|
|
|
|
|
|
|
Copyright (C) 2009 Michael Adam <obnox@samba.org>
|
|
|
|
|
|
|
|
This program is distributed under the terms of the GNU General Public License
|
|
|
|
version 2 or above. See the COPYING file for additional information.
|
|
|
|
|
2009-09-17 04:27:57 +08:00
|
|
|
=cut
|