HTTPS Proxy i LWP :: UserAgent
Przeczytałem wiele wątków w wielu witrynach i nadal nie mogę wykonać tej pracy.
Mam komputer kliencki (OSX) z OpenSSL 0.9.8r z uruchomionym Perl 5.12.4, z LWP 6.0.4, zaktualizowany Crypt :: SSLeay, Net :: SSL itp. Próbuję połączyć się z witryną HTTPS (https://github.com w przykładzie) przez proxy WinGate, które uruchomiłem na maszynie wirtualnej z systemem Windows. Zauważ, że moja aktualna aplikacja dołącza do usługi SSL, nad którą nie mam kontroli.
Od Firefoksa wskazano na proxy wszystko jest copacetic. Strona ładuje się pomyślnie i widzę połączenia w monitorze aktywności oprogramowania proxy. Będę jednak cholernie szczęśliwy, jeśli uda mi się to zrobić w Perlu. Zacząłem od kodu z tego pytania o przepełnienie stosu:Jak zmusić LWP do używania Crypt :: SSLeay do żądań HTTPS? I dodał trochę debugowania i dodatkowego wyjścia. Oto stałem teraz:
#!/usr/bin/perl
use strict;
use warnings;
use Net::SSL (); # From Crypt-SSLeay
BEGIN {
$Net::HTTPS::HTTPS_SSL_SOCKET_CLASS = "Net::SSL"; # Force use of Net::SSL
$ENV{HTTPS_PROXY} = 'https://192.168.1.11:80';
# $ENV{PERL_LWP_SSL_VERIFY_HOSTNAME} = 0;
$ENV{HTTPS_DEBUG} = 1; #Add debug output
}
use LWP::UserAgent;
my $ua = LWP::UserAgent->new();
my $req = HTTP::Request->new('GET','https://github.com/');
my $response = $ua->request($req);
print "--\n";
print "$_\n" for grep { $_ =~ /SSL/ } keys %INC;
print "--\n";
if ($response->is_success) {
print $response->decoded_content; # or whatever
exit(0);
}
else {
print "\nFail:\n";
print $response->status_line ."\n";
exit(1);
}
Oto wynik tego kodu:
--
Crypt/SSLeay.pm
Crypt/SSLeay/X509.pm
Net/SSL.pm
--
Fail:
500 Can't connect to github.com:443 (Crypt-SSLeay can't verify hostnames)
Jeśli wtedy odkomentuję$ENV{PERL_LWP_SSL_VERIFY_HOSTNAME} = 0;
, Widzę pojedyncze połączenie z github.com:443 na serwerze proxy, a potem nic.(Zauważ, że działa świetnie z przeglądarki internetowej przez proxy). Po długim zawieszeniu otrzymuję następujący wynik skryptu:
SSL_connect:before/connect initialization
SSL_connect:SSLv2/v3 write client hello A
SSL_connect:before/connect initialization
SSL_connect:SSLv3 write client hello A
SSL_connect:failed in SSLv3 read server hello A
SSL_connect:before/connect initialization
SSL_connect:SSLv2 write client hello A
SSL_connect:failed in SSLv2 read server hello A
--
Crypt/SSLeay.pm
Crypt/SSLeay/X509.pm
Net/SSL.pm
Crypt/SSLeay/CTX.pm
Crypt/SSLeay/MainContext.pm
--
Fail:
500 SSL negotiation failed:
Jeśli ktokolwiek może tu wskazać kierunek, byłbym bardzo wdzięczny!