Скрипт для авторизации на сайте vkontakte.ru.

Статус
В этой теме нельзя размещать новые ответы.

felix90

Постоялец
Регистрация
15 Июл 2007
Сообщения
109
Реакции
20
Если база данных с e-mail и pass. Нужно: сделать php скрипт, который будет брать e-mail;pass, пробовать залогиниться на контакте, если удачно - сохраняем этот e-mail и пароль в файл, если нет - пропускаем и берём следующую пару e-mail;pass. Написал функцию для коннекта, но столкнулся с проблемой с cookies. Если знать id пользователя, тогда с коннектом проблем нет, а в нашем случае мы его не знаем.

HTML:
 function connect($mail,$pass){

$link = 'http://vkontakte.ru/profile.php';
$ua = 'User-Agent: Mozilla/4.0 (compatible; MSIE 5.01; Widows NT)'; // ну, или что больше нравится
  //$cookie='remixmid='.$id.'; remixemail='.$mail.'; remixpass='.md5($pass).'; remixlang=3; remixchk=5; '.$cookie_hash;
  $post = "email=".$mail."&pass=".$pass;
        $ch = curl_init($link);
        curl_setopt ($ch, CURLOPT_HEADER, 1); // чтобы выводил заголовки
        curl_setopt ($ch, CURLOPT_NOBODY, 1); // чтобы не выводил саму страницу (она пока не нужна)
        curl_setopt($ch, CURLOPT_USERAGENT, $ua); // чтобы сказать что мы броузер, а не так себе...
        ob_start(); // первый раз ничего не нужно выводить (можно для отладки скрипта убрать)
        
        curl_exec ($ch);
curl_close ($ch);
        
$headers = explode("\n", ob_get_contents()); // так можно получить массив всех заголовков от сервера
ob_end_clean();

for ($i=0; $i>sizeof($headers); $i++) 
{ 
if (strpos($headers, 'Set-Cookie:') !== FALSE) 
{ 
list($field, $cookie[]) = explode(' ', $headers[$i]); // так можно получить куку (куки)
} 
}
        $ch = curl_init($link);
        curl_setopt($ch, CURLOPT_URL,$link);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
        curl_setopt($ch, CURLOPT_TIMEOUT, 0);
         curl_setopt($ch, CURLOPT_POST, true);
         curl_setopt($ch, CURLOPT_POSTFIELDS, $post);
         curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
        curl_setopt($ch, CURLOPT_HEADER, 1);
        curl_setopt($ch, CURLOPT_USERAGENT, $ua); 

curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); // это может понадобиться если будет редирект

for ($i=0; $i>sizeof($cookie); $i++) 
{ 
curl_setopt($ch, CURLOPT_COOKIE, $cookie[$i]); // шлём куку (куки)
} 

ob_start();

$headers = explode("\n", ob_get_contents()); 
ob_end_clean();

for ($i=0; sizeof($headers); $i++) 
{ 
if (strpos($headers, 'Set-Cookie:') !== FALSE) 
{ 
list($field, $cookie[]) = explode(' ', $headers[$i]); 
} 
}

for ($i=0; sizeof($cookie); $i++) 
{ 
curl_setopt($ch, CURLOPT_COOKIE, $cookie[$i]); // шлём куку
}
        $otvet = curl_exec($ch);
        curl_close($ch);
return $otvet;
}

Не хочет коннектится. Поможите?
 
Есть пример проги, которая с имени и паса делает куки

В архиве, есть исходник программы, если его посмотреть увидишь как получают куки - перевести на php не сложно будет.
 
Есть пример проги, которая с имени и паса делает куки
*** скрытое содержание ***
В архиве, есть исходник программы, если его посмотреть увидишь как получают куки - перевести на php не сложно будет.
Я с делфи не работал, так что не смогу в коде разобраться :(
 
Я нашёл класс, при помощи которого всё легко можно сделать. Вот пример скрипта с применением этого класса:
Код:
<?
require_once "Curl.php";

$email = 'mail@mail.ru';
$pass = 'pass';

        
/** [! Авторизация **/
$curl = new Curl();
$curl->init("http://vkontakte.ru/login.php")->serverfriendly()->setopt("post",array("email"=>$email,"pass"=>$pass))->exec(); // авторизуемся. далее будем использовать этот объект.
$curl->addCookie("remixlang",array("value"=>"0"));
/** Авторизация !] **/

if($curl->getHeader("location")) die ('good');
else echo 'bad';

?>
Но вот теперь созрело одно большое НО! Класс не хочет работать на платном виртуальном хостинге :(. Испробовал 3 разных хостинг компании и ничего. Просто скрипт долго думает и в итоге выдаёт белый экран. Не подскажите в чём может быть проблема?

P.S. На денвере всё работает отлично!..

Вот сам Curl.php:
Код:
<?php

class Curl

{

    private $_ch;

    private $_opts;

    private $_content;

    private $_headers;

    private $_options;

    private $_cookies;

    private $_tmpfile;



    public $curlinfo;



    public function __construct()

    {

        if (!extension_loaded('curl')) {

            if (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') {

                dl('curl.dll');

            } else {

                dl('curl.so');

            }

        }

        if (!extension_loaded('curl'))

        {

            die("<b>Unable to load extension Curl! Application Exit</b><br/>");

        }

        $this->_ch = false;

        $this->_opts = unserialize('a:96:{s:11:"autoreferer";s:19:"CURLOPT_AUTOREFERER";s:14:"binarytransfer";s:22:"CURLOPT_BINARYTRANSFER";s:10:"buffersize";s:18:"CURLOPT_BUFFERSIZE";s:6:"cainfo";s:14:"CURLOPT_CAINFO";s:6:"capath";s:14:"CURLOPT_CAPATH";s:11:"closepolicy";s:19:"CURLOPT_CLOSEPOLICY";s:14:"connecttimeout";s:22:"CURLOPT_CONNECTTIMEOUT";s:6:"cookie";s:14:"CURLOPT_COOKIE";s:10:"cookiefile";s:18:"CURLOPT_COOKIEFILE";s:9:"cookiejar";s:17:"CURLOPT_COOKIEJAR";s:13:"cookiesession";s:21:"CURLOPT_COOKIESESSION";s:4:"crlf";s:12:"CURLOPT_CRLF";s:13:"customrequest";s:21:"CURLOPT_CUSTOMREQUEST";s:17:"dns_cache_timeout";s:25:"CURLOPT_DNS_CACHE_TIMEOUT";s:20:"dns_use_global_cache";s:28:"CURLOPT_DNS_USE_GLOBAL_CACHE";s:9:"egdsocket";s:17:"CURLOPT_EGDSOCKET";s:8:"encoding";s:16:"CURLOPT_ENCODING";s:11:"failonerror";s:19:"CURLOPT_FAILONERROR";s:4:"file";s:12:"CURLOPT_FILE";s:8:"filetime";s:16:"CURLOPT_FILETIME";s:14:"followlocation";s:22:"CURLOPT_FOLLOWLOCATION";s:12:"forbid_reuse";s:20:"CURLOPT_FORBID_REUSE";s:13:"fresh_connect";s:21:"CURLOPT_FRESH_CONNECT";s:9:"ftpappend";s:17:"CURLOPT_FTPAPPEND";s:8:"ftpascii";s:16:"CURLOPT_FTPASCII";s:11:"ftplistonly";s:19:"CURLOPT_FTPLISTONLY";s:7:"ftpport";s:15:"CURLOPT_FTPPORT";s:10:"ftpsslauth";s:18:"CURLOPT_FTPSSLAUTH";s:7:"ftp_ssl";s:15:"CURLOPT_FTP_SSL";s:12:"ftp_use_eprt";s:20:"CURLOPT_FTP_USE_EPRT";s:12:"ftp_use_epsv";s:20:"CURLOPT_FTP_USE_EPSV";s:6:"header";s:14:"CURLOPT_HEADER";s:14:"headerfunction";s:22:"CURLOPT_HEADERFUNCTION";s:14:"http200aliases";s:22:"CURLOPT_HTTP200ALIASES";s:8:"httpauth";s:16:"CURLOPT_HTTPAUTH";s:7:"httpget";s:15:"CURLOPT_HTTPGET";s:10:"httpheader";s:18:"CURLOPT_HTTPHEADER";s:15:"httpproxytunnel";s:23:"CURLOPT_HTTPPROXYTUNNEL";s:12:"http_version";s:20:"CURLOPT_HTTP_VERSION";s:6:"infile";s:14:"CURLOPT_INFILE";s:10:"infilesize";s:18:"CURLOPT_INFILESIZE";s:9:"interface";s:17:"CURLOPT_INTERFACE";s:9:"krb4level";s:17:"CURLOPT_KRB4LEVEL";s:15:"low_speed_limit";s:23:"CURLOPT_LOW_SPEED_LIMIT";s:14:"low_speed_time";s:22:"CURLOPT_LOW_SPEED_TIME";s:11:"maxconnects";s:19:"CURLOPT_MAXCONNECTS";s:9:"maxredirs";s:17:"CURLOPT_MAXREDIRS";s:4:"mute";s:12:"CURLOPT_MUTE";s:5:"netrc";s:13:"CURLOPT_NETRC";s:6:"nobody";s:14:"CURLOPT_NOBODY";s:10:"noprogress";s:18:"CURLOPT_NOPROGRESS";s:8:"nosignal";s:16:"CURLOPT_NOSIGNAL";s:14:"passwdfunction";s:22:"CURLOPT_PASSWDFUNCTION";s:4:"port";s:12:"CURLOPT_PORT";s:4:"post";s:12:"CURLOPT_POST";s:10:"postfields";s:18:"CURLOPT_POSTFIELDS";s:9:"postquote";s:17:"CURLOPT_POSTQUOTE";s:5:"proxy";s:13:"CURLOPT_PROXY";s:9:"proxyauth";s:17:"CURLOPT_PROXYAUTH";s:9:"proxyport";s:17:"CURLOPT_PROXYPORT";s:9:"proxytype";s:17:"CURLOPT_PROXYTYPE";s:12:"proxyuserpwd";s:20:"CURLOPT_PROXYUSERPWD";s:3:"put";s:11:"CURLOPT_PUT";s:5:"quote";s:13:"CURLOPT_QUOTE";s:11:"random_file";s:19:"CURLOPT_RANDOM_FILE";s:5:"range";s:13:"CURLOPT_RANGE";s:8:"readdata";s:16:"CURLOPT_READDATA";s:12:"readfunction";s:20:"CURLOPT_READFUNCTION";s:7:"referer";s:15:"CURLOPT_REFERER";s:11:"resume_from";s:19:"CURLOPT_RESUME_FROM";s:14:"returntransfer";s:22:"CURLOPT_RETURNTRANSFER";s:7:"sslcert";s:15:"CURLOPT_SSLCERT";s:13:"sslcertpasswd";s:21:"CURLOPT_SSLCERTPASSWD";s:11:"sslcerttype";s:19:"CURLOPT_SSLCERTTYPE";s:9:"sslengine";s:17:"CURLOPT_SSLENGINE";s:17:"sslengine_default";s:25:"CURLOPT_SSLENGINE_DEFAULT";s:6:"sslkey";s:14:"CURLOPT_SSLKEY";s:12:"sslkeypasswd";s:20:"CURLOPT_SSLKEYPASSWD";s:10:"sslkeytype";s:18:"CURLOPT_SSLKEYTYPE";s:10:"sslversion";s:18:"CURLOPT_SSLVERSION";s:15:"ssl_cipher_list";s:23:"CURLOPT_SSL_CIPHER_LIST";s:14:"ssl_verifyhost";s:22:"CURLOPT_SSL_VERIFYHOST";s:14:"ssl_verifypeer";s:22:"CURLOPT_SSL_VERIFYPEER";s:6:"stderr";s:14:"CURLOPT_STDERR";s:13:"timecondition";s:21:"CURLOPT_TIMECONDITION";s:7:"timeout";s:15:"CURLOPT_TIMEOUT";s:9:"timevalue";s:17:"CURLOPT_TIMEVALUE";s:12:"transfertext";s:20:"CURLOPT_TRANSFERTEXT";s:17:"unrestricted_auth";s:25:"CURLOPT_UNRESTRICTED_AUTH";s:6:"upload";s:14:"CURLOPT_UPLOAD";s:3:"url";s:11:"CURLOPT_URL";s:9:"useragent";s:17:"CURLOPT_USERAGENT";s:7:"userpwd";s:15:"CURLOPT_USERPWD";s:7:"verbose";s:15:"CURLOPT_VERBOSE";s:13:"writefunction";s:21:"CURLOPT_WRITEFUNCTION";s:11:"writeheader";s:19:"CURLOPT_WRITEHEADER";}');

    }



    public function init($url = false,$options=array())

    {

        $this->_ch = curl_init();



        if($url)

        {

            $options['url'] = $url;

            $options['referer'] = dirname($url)."/";

        }



        $this->_headers = array();

        $this->_options = array();

        return $this->options($options);

    }





    public function serverfriendly()

    {

        $options = array();

        $options['ssl_verifyhost'] = 0;

        $options['ssl_verifypeer'] = 0;

        $options['useragent'] = "phpdude Curl v0.1b";

        $options['referer'] = dirname($options['url']);

        $options['httpheader'] = array("Accept-Charset: windows-1251,utf-8;q=0.7,*;q=0.7;","Keep-Alive: 300","Connection: keep-alive","Accept: */*");



        return $this->options($options);

    }



    public function setopt($option,$value)

    {

        $option = strtolower($option);



        if(!array_key_exists($option,$this->_opts))

        {

            trigger_error("Option: <b>$option</b> Not Found!", E_USER_ERROR);

        }



        $this->_options[$option] = $value;

        if($option=="cookie" || $option=="post")

        {

            return $this;

        }

        if($option=="httpheader")

        {

            $this->_options['httpheader'] = array_unique(@array_merge((array)$this->_options['httpheader'],(array)$value));


        }



        curl_setopt($this->_ch,constant($this->_opts[$option]),$value);



        return $this;

    }



    public function options($options)

    {

        if(!is_array($options) || !$options)

        {

            return false;

        }

        foreach($options as $key=>$val)

        {

            $this->setopt($key,$val);

        }

        return $this;

    }



    public function exec($return = true,$newcookiesession=false)

    {

        $this->mr_before_exec($return,$newcookiesession);

        return $this->mr_after_exec(curl_exec($this->_ch));

    }



    public function mr_before_exec($return = true,$newcookiesession=false)

    {

        $this->_tmpfile = tmpfile();



        curl_setopt($this->_ch, CURLOPT_WRITEHEADER,$this->_tmpfile);

        curl_setopt($this->_ch, CURLOPT_RETURNTRANSFER,$return ? 1 : 0);

        curl_setopt($this->_ch, CURLOPT_HEADER, 0);

        curl_setopt($this->_ch, CURLOPT_CRLF, 1);



        if(@$this->_options['cookie'] || $sesscookies = $this->getCookies($this->_options['url']))

        {

            $cookies = (array)$this->_options['cookie'];

            if($newcookiesession)

            {

                $this->_cookies = array();

            }

            else

            {

                $cookies = array_merge($cookies,$sesscookies);

            }

            curl_setopt($this->_ch,CURLOPT_COOKIE, http_build_query($cookies,"","; "));

        }



        if(@$this->_options['post'])

        {

            $postfields = is_array($this->_options['post']) ? http_build_query($this->_options['post'],"","&") : $this->_options['post'];

            curl_setopt($this->_ch,CURLOPT_POSTFIELDS, $postfields);

            curl_setopt($this->_ch,CURLOPT_POST, 1);

        }

        return $this;

    }



    public function mr_after_exec($result)

    {

        if(curl_errno($this->_ch))

        {

            throw new Exception("CURL ERROR: ".curl_error($this->_ch),curl_errno($this->_ch));

        }

            

        $info = curl_getinfo($this->_ch);

        $this->curlinfo = new stdClass();

        foreach($info as $f=>$v)

        {

            $this->curlinfo->$f = $v;

        }



        curl_close($this->_ch);

        $this->_content = $result;



        $this->_header_parser();



        $charset = "";

        if($contenttype = $this->getHeader("content-type"))

        {

            $contenttype = is_array($contenttype) ? $contenttype[0] : $contenttype;

            if(preg_match('#text/html\s*;\s*charset\s*=\s*([^\s]+)#i',$contenttype,$charset))

            {

                $charset = $charset[1];

            }

        }

        if(preg_match("#<meta[^>]+Content.Type[^>]+>#ism",$this->_content,$contenttype))

        {

            if(preg_match('#\s*;\s*charset\s*=\s*(["\'a-z0-9\\-]+)#i',$contenttype[0],$chset))

            {

                $charset = trim($chset[1],"\"'");

            }

        }

        if($charset && strtolower($charset)!="utf-8")

        {

            $this->_content = iconv($charset,"UTF-8",$this->_content);

        }



        return $this->_content;

    }



    public function getOptionsList()

    {

        echo "<pre>";

        print_r($this->_opts);

        echo "</pre>";

    }



    public function getContent()

    {

        return $this->_content;

    }



    public function getOptions()

    {

        return $this->_options;

    }



    public function getOption($name)

    {

        return @$this->_options[$name];

    }



    public function getHeaders()

    {

        return $this->_headers;

    }



    public function getHeader($name)

    {

        return @$this->_headers[$this->_normalize($name)];

    }



    public function addCookies($cookies)

    {

        $this->_cookies = @array_merge((array)$this->_cookies,$cookies);

        return $this;

    }



    public function addCookie($name, $data)

    {

        $this->_cookies[$name] = $data;

        return $this;

    }



    public function getCookies($url="",$name=false,$valueonly = true)

    {

        if(!$url)

        {

            $cookies = $name ? array($this->cookie($name,true)) : $this->_cookies;

            if($valueonly)

            {

                foreach($cookies as $k=>$cookie)

                {

                    $cookies[$k] = $valueonly ? $cookie['value'] : $cookie;

                }

            }

            return $cookies;

        }



        $domain = ltrim(parse_url($url,PHP_URL_HOST),".");

        $path = parse_url($url,PHP_URL_PATH);



        $cookies = $name ? array($name => $this->cookie($name)) : (array)$this->_cookies;



        $return = array();

        foreach($cookies as $name=>$cookie)

        {

            if(!@$cookie['path'] || !$cookie['domain'] || (strpos($path,$cookie['path'])!==false && strpos($domain,ltrim($cookie['domain'],"."))!==false))

            {

                $return[$name] = $valueonly ? $cookie['value'] : $cookie;

            }

        }



        return $return;

    }



    public function getChannel()

    {

        return $this->_ch;

    }



    public function setChannel($ch)

    {

        $this->_ch = $ch;

    }



    public function cookie($name,$allinfo = false)

    {

        $cookie = @$this->_cookies[$name];

        if($allinfo)

        {

            return $cookie;

        }

        else

        {

            return @$cookie['value'];

        }

    }



    private function strip($content)

    {

        return preg_replace("#\\s+#"," ",$content);

    }



    private function _header_parser()

    {

        $tmpfile = $this->_tmpfile;



        fseek($tmpfile,0);

        fgets($tmpfile);

        while(!feof($tmpfile) && is_resource($tmpfile))

        {

            $line = trim(fgets($tmpfile));

            if(!$line)

            {

                continue;

            }



            $header = $this->_normalize(substr($line,0,strpos($line,":")));

            $val = trim(substr($line,strpos($line,":")+1));

            if(!@$this->_headers[$header])

            {

                $this->_headers[$header] = $val;

            }

            else

            {

                if(!is_array($this->_headers[$header]))

                {

                    $this->_headers[$header] = array($this->_headers[$header]);

                }

                $this->_headers[$header][] = $val;

            }

        }



        $this->_cookies_parser();

    }



    private function _cookies_parser()

    {

        $cookies = $this->getHeader("Set-Cookie");

        if(!$cookies)

        {

            return;

        }

        if(!is_array($cookies))

        {

            $cookies = array($cookies);

        }

        foreach($cookies as $cookie)

        {

            $cookiename = "";

            $cookieinfo = array();

            $data = explode(";",$cookie);

            foreach($data as $part)

            {

                $parts = explode("=",$part);

                if(!$cookiename)

                {

                    $cookiename = $parts[0];

                    $cookieinfo = array("value"=>urldecode($parts[1]));

                }

                else

                {

                    $cookieinfo[$this->_normalize($parts[0])] = $parts[1];

                }



            }

            $this->_cookies[$cookiename] = $cookieinfo;

        }

    }



    private function _normalize($str)

    {

        return strtolower(trim($str));

    }

}
?>
 
Мб дело в Safe_mode PHP ?
 
На сервере pph_curl.dll включено?
 
Причем тут пошутил? Какой вопрос - такой совет.
Больше информации нужно.
 
Статус
В этой теме нельзя размещать новые ответы.
Назад
Сверху