Проблема с получением содержимого сайта через cURL по HTTP (SSL), Cookie, Имя пользователя: Пароль - PullRequest
0 голосов
/ 20 февраля 2011

У меня проблемы с cURL,

Проблемы - не удается подключиться через HTTP (SSL) - не в состоянии хранить куки - невозможно войти в систему под именем пользователя: пароль

Есть ли что-то похожее на иерархию в curl_setopt?

Я надеюсь, что получу лучший ответ. Заранее спасибо

<?php
function get_url($url,$username,$password)
{
$curl = curl_init();

$header[0] = "Accept: text/xml,application/xml,application/xhtml+xml,";
$header[0] .= "text/html;q=0.9,text/plain;q=0.8,image/png,*/*;q=0.5";
$header[] = "Cache-Control: max-age=0";
$header[] = "Connection: keep-alive";
$header[] = "Keep-Alive: 300";
$header[] = "Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7";
$header[] = "Accept-Language: en-us,en;q=0.5";
$header[] = "Pragma: ";

$cookie = '/cookies.txt';
$timeout = 30;

curl_setopt($curl, CURLOPT_URL,             $url);
curl_setopt($curl, CURLOPT_USERAGENT,       "Mozilla/5.0 (Windows; U; Windows NT 5.1; rv:1.7.3) Gecko/20041001 Firefox/0.10.1" );
curl_setopt($curl, CURLOPT_HTTPHEADER,      $header);
curl_setopt($curl, CURLOPT_ENCODING,        'gzip,deflate'); 
curl_setopt($curl, CURLOPT_AUTOREFERER,     true); 
curl_setopt($curl, CURLOPT_TIMEOUT,         10); 
curl_setopt($curl, CURLOPT_CONNECTTIMEOUT,  $timeout );
curl_setopt($curl, CURLOPT_COOKIEJAR,       $cookie);
curl_setopt($curl, CURLOPT_COOKIEFILE,      $cookie);
curl_setopt($curl, CURLOPT_RETURNTRANSFER,  true);
curl_setopt($curl, CURLOPT_FOLLOWLOCATION,  true );
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER,  false );    # required for https urls
curl_setopt($curl, CURLOPT_MAXREDIRS,       10 );
curl_setopt($curl, CURLOPT_HTTPAUTH,        CURLAUTH_BASIC);
curl_setopt($curl, CURLOPT_USERPWD,         "$username:$password");

$responseHTML   = curl_exec($curl);
$response       = curl_getinfo( $curl );

curl_close($curl); // close the connection

//return $html; // and finally, return $html


if ($response['http_code'] == 301 || $response['http_code'] == 302)
{
    ini_set("user_agent", "Mozilla/5.0 (Windows; U; Windows NT 5.1; rv:1.7.3) Gecko/20041001 Firefox/0.10.1");

    if ( $headers = get_headers($response['url']) )
    {
        foreach( $headers as $value )
        {
            if ( substr( strtolower($value), 0, 9 ) == "location:" )
                return get_url( trim( substr( $value, 9, strlen($value) ) ) );
        }
    }
}

if (
    (preg_match("/>[[:space:]]+window\.location\.replace\('(.*)'\)/i", $content, $value) 
    || preg_match("/>[[:space:]]+window\.location\=\"(.*)\"/i", $content, $value))
    && $javascript_loop < 5
)
{
    return get_url( $value[1], $javascript_loop+1 );
}
else
{
    return $responseHTML; //array( $content, $response );
}
}


$url = 'https://blog.example.com/wp-login.php';
$user = 'admin';
$pass = 'thesecurepassword123';

// uses the function and displays the text off the website
$text = get_url($url,$user,$pass);
echo $text;
?>

1 Ответ

1 голос
/ 20 февраля 2011

Имя пользователя и пароль, которые вы предоставляете, предназначены для HTTP-аутентификации (вы когда-нибудь посещали сайт, на котором всплывало маленькое окошко, похожее на окно оповещения о необходимости ввода имени пользователя и пароля?), Но ваш URL выглядит так, как будто вы запрашиваетестраница входа в WordPress.Вот почему вы не можете войти с этим именем пользователя и паролем.

Я полагаю, что WordPress принимает параметры входа в систему как переменные POST - имя пользователя берется как «log», а пароль - как «pwd».Попробуйте отправить имя пользователя и пароль в качестве этих переменных POST, это должно сработать.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...