#!/usr/bin/perl use strict; use IO::Socket; use LWP::UserAgent; my $host = "bbs.chinaunix.net"; my $html = ""; my $start = ""; my $end = ""; my $ua = LWP::UserAgent -> new; $ua -> timeout( 30 ); $ua -> agent( 'Mozilla/4.76 [en] (Win98; U)' ); $ua -> default_header( 'Pragma' => 'no-cache', 'Accept' => '*/*'); $start = time; print "LWP strat " . $start . "\n"; my $resp = $ua -> get( "http://$host/" ); if ( $resp -> is_success ) { $html = $resp->status_line ."\n\n"; $html .= $resp->headers_as_string ."\n\n"; $html .= $resp -> content; } $end = time; print "LWP end " . $end . "\n"; print "LWP time = " . ($end - $start) . "\n\n"; $html = ""; my $geturl=qq~GET / HTTP/1.1 Accept: */* User-Agent: Mozilla/4.76 [en] (Win98; U) Host: $host Connection: Keep-Alive ~; $start = time; print "IO::Socket::INET strat " . $start . "\n"; my $socket = IO::Socket::INET->new(Proto=>"tcp", PeerAddr=>"$host", PeerPort=>80, Timeout => 30); $socket->autoflush(1); my @html; if($socket){ print $socket "$geturl"; print "IO::Socket::INET time1 " . time . "\n"; @html=<$socket>; # Attention here, why spent so much time? print "IO::Socket::INET time2 " . time . "\n"; close($socket); }else{ } $html = join("",@html); $end = time; print "IO::Socket::INET end " . $end . "\n"; print "IO::Socket::INET time = " . ($end - $start) . "\n\n";