NAME

HTTP::Lite - Lightweight HTTP implementation

SYNOPSIS

use HTTP::Lite;
$http = new HTTP::Lite;
$req = $http->request("http://www.cpan.org/") 
    or die "Unable to get document: $!";
print $http->body();

DESCRIPTION

HTTP::Lite is a stand-alone lightweight HTTP/1.1 implementation
for perl.  It is not intended as a replacement for the
fully-features LWP module.  Instead, it is intended for use in
situations where it is desirable to install the minimal number of
modules to achieve HTTP support, or where LWP is not a good
candidate due to CPU overhead, such as slower processors.
HTTP::Lite is also significantly faster than LWP.

HTTP::Lite is ideal for CGI (or mod_perl) programs or for bundling
for redistribution with larger packages where only HTTP GET and
POST functionality are necessary.

HTTP::Lite supports basic POST and GET operations only.  As of
0.2.1, HTTP::Lite supports HTTP/1.1 and is compliant with the Host
header, necessary for name based virtual hosting.  Additionally,
HTTP::Lite now supports Proxies.

As of 2.0.0 HTTP::Lite now supports a callback to allow processing
of request data as it arrives.  This is useful for handling very
large files without consuming memory.

If you require more functionality, such as FTP or HTTPS, please
see libwwwperl (LWP).  LWP is a significantly better and more
comprehensive package than HTTP::Lite, and should be used instead
of HTTP::Lite whenever possible.

CONSTRUCTOR

new

This is the constructor for HTTP::Lite. It presently takes no arguments. A future version of HTTP::Lite might accept parameters.

METHODS

request ( URL, CALLBACK, CBARGS )

Initiates a request to the specified URL.

Returns undef if an I/O error is encountered, otherwise the HTTP status code will be returned. 200 series status codes represent success, 300 represent temporary errors, 400 represent permanent errors, and 500 represent server errors.

See http://www.w3.org/Protocols/HTTP/HTRESP.html for detailled information about HTTP status codes.

The CALLBACK parameter, if used, is a way to filter the data as it is received or to handle very large transfers. It must be a function reference, and will be passed: a reference to the instance of the http request making the callback, a reference to the current block of data about to be added to the body, and the CBARGS parameter (which may be anything). It must return either a reference to the data to add to the body of the document, or undef.

An example use to save a document to file is:

# Write the data to the filehandle $cbargs
sub savetofile {
  my ($self,$dataref,$cbargs) = @_;
  print $cbargs $$dataref;
  return undef;
}

$url = "$testpath/bigbinary.dat";
open OUT, ">bigbinary.dat";
$res = $http->request($url, \&callback2, OUT);
close OUT;
prepare_post ( $hashref )

Takes a reference to a hashed array of post form variables to upload. Create the HTTP body and sets the method to POST.

http11_mode ( 0 | 1 )

Turns on or off HTTP/1.1 support. This is off by default due to broken HTTP/1.1 servers. Use 1 to enable HTTP/1.1 support.

add_req_header ( $header, $value )
get_req_header ( $header )
delete_req_header ( $header )

Add, Delete, or a HTTP header(s) for the request. These functions allow you to override any header. Presently, Host, User-Agent, Content-Type, Accept, and Connection are pre-defined by the HTTP::Lite module. You may not override Host, Connection, or Accept.

To provide (proxy) authentication or authorization, you would use:

use HTTP::Lite;
use MIME::Base64;
$http = new HTTP::Lite;
$encoded = encode_base64('username:password');
$http->add_req_header("Authorization", $encoded);

NOTE: The present implementation limits you to one instance of each header.

body

Returns the body of the document retured by the remote server.

headers_array

Returns an array of the HTTP headers returned by the remote server.

headers_string

Returns a string representation of the HTTP headers returned by the remote server.

get_header ( $header )

Returns an array of values for the requested header.

NOTE: HTTP requests are not limited to a single instance of each header. As a result, there may be more than one entry for every header.

protocol

Returns the HTTP protocol identifier, as reported by the remote server. This will generally be either HTTP/1.0 or HTTP/1.1.

proxy ( $proxy_server )

The URL or hostname of the proxy to use for the next request.

status

Returns the HTTP status code returned by the server. This is also reported as the return value of request().

status_message

Returns the textual description of the status code as returned by the server. The status string is not required to adhere to any particular format, although most HTTP servers use a standard set of descriptions.

reset

You must call this prior to re-using an HTTP::Lite handle, otherwise the results are undefined.

EXAMPLES

# Get and print out the headers and body of the CPAN homepage
use HTTP::Lite;
$http = new HTTP::Lite;
$req = $http->request("http://www.cpan.org/")
    or die "Unable to get document: $!";
die "Request failed ($req): ".$http->status_message()
  if $req ne "200";
@headers = $http->headers_array();
$body = $http->body();
foreach $header (@headers)
{
  print "$header$CRLF";
}
print "$CRLF";
print "$body$CRLF";

# POST a query to the dejanews USENET search engine
use HTTP::Lite;
$http = new HTTP::Lite;
%vars = (
         "QRY" => "perl",
         "ST" => "MS",
         "svcclass" => "dncurrent",
         "DBS" => "2"
        );
$http->prepare_post(\%vars);
$req = $http->request("http://www.deja.com/dnquery.xp")
  or die "Unable to get document: $!";
print "req: $req\n";
print $http->body();

UNIMPLEMENTED

- FTP 
- HTTPS (SSL)
- Authenitcation/Authorizaton/Proxy-Authorization
  are not directly supported, and require MIME::Base64.
- Redirects (Location) are not automatically followed
- multipart/form-data POSTs are not supported (necessary for
  File uploads).

BUGS

Large requests are stored in ram, potentially more than once
due to HTTP/1.1 chunked transfer mode support.  A future
version of this module may support writing requests to a
filehandle to avoid excessive disk use.

Some broken HTTP/1.1 servers send incorrect chunk sizes
when transferring files.  HTTP/1.1 mode is now disabled by
default.

AUTHOR

Roy Hooper <rhooper@thetoybox.org>

SEE ALSO

LWP RFC 2068 - HTTP/1.1 -http://www.w3.org/

COPYRIGHT

Copyright (c) 2000-2002 Roy Hooper. All rights reserved.

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

1 POD Error

The following errors were encountered while parsing the POD:

Around line 769:

You forgot a '=back' before '=head1'