我无法通过curl登录该站点

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了我无法通过curl登录该站点相关的知识,希望对你有一定的参考价值。

我不明白自己在做什么错。有服务站点:https://demo.moneta.ru/login.htm。带令牌的通常形式。我敲开页面,保存cookie,从表单中获取令牌。我从表单数据发送到地址的下一个请求。带有cookie和令牌。我有一个无花果。 401。

我检查了所有内容,发送了相同的数据,相同的标头。告诉我,我想念什么?

$receipt = new Receipt;

$receipt->get_scrf();
echo $receipt->get_auth();

Class Receipt {
    private $scrf;

    private $login_page_url = 'https://demo.moneta.ru/login.htm';
    private $login_action_url = 'https://demo.moneta.ru/login';

    private $login = 'LOGIN';
    private $password = "PASSWORD";

    public function get_auth(){
    $headers = [
        'Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9',
        'Accept-Encoding: gzip, deflate, br',
        'Accept-Language: ru-RU,ru;q=0.9,en-US;q=0.8,en;q=0.7',
        'Cache-Control: max-age=0',
        'Origin: https://demo.moneta.ru',
        'Referer: https://demo.moneta.ru/login.htm',
        'Sec-Fetch-Dest: document',
        'Sec-Fetch-Mode: navigate',
        'Sec-Fetch-Site: same-origin',
        'Sec-Fetch-User: ?1',
        'Upgrade-Insecure-Requests: 1',
        'User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.132 Safari/537.36',
        'Content-Type: application/x-www-form-urlencoded',
        'Connection: keep-alive'
    ];

        $post = [
            'state' => $this->scrf,
            'target' => 'desktop',
            'login' => $this->login,
            'password' => $this->password
        ];

        return $this->get_page($this->login_action_url, $post, $headers);
    }

    public function get_scrf(){
        $page_html = $this->get_page($this->login_page_url);

        preg_match('/<input type="hidden" name="state" value="([0-9a-z-]+)">/', $page_html, $matches, PREG_OFFSET_CAPTURE);

        if(isset($matches[1][0])){
            $this->scrf = $matches[1][0];
            return $matches[1][0];
        }
        return null;
    }

    private function get_page($url, $post=null, $headers=null){
        $ch = curl_init();
        curl_setopt($ch, CURLOPT_URL, $url );
        curl_setopt($ch, CURLOPT_HEADER, 0);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
        curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 30);
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
        curl_setopt($ch, CURLOPT_COOKIEJAR, dirname(__FILE__).'/cookie.txt');
        curl_setopt($ch, CURLOPT_COOKIEFILE,  dirname(__FILE__).'/cookie.txt');
        curl_setopt($ch, CURLOPT_POST, $post!==null );

        if($headers){
            curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
        }

        if($post){
            curl_setopt($ch, CURLOPT_POSTFIELDS, $post);
        }
        $data = curl_exec($ch);
        curl_close($ch);
        return $data;
    }
}

Request from browser

答案

您有

curl_setopt($ch, CURLOPT_POSTFIELDS, $post);

其中$post是关联数组。

来自documentation

如果value是一个数组,则Content-Type标头将设置为multipart / form-data

这不是表单的行为,与您显式设置的Content-Type头冲突:

'Content-Type: application/x-www-form-urlencoded'

尝试将POST数据作为URL编码的字符串传递到curl_setopt($ch, CURLOPT_POSTFIELDS, ...

您只需要http_build_query()

http_build_query()

以上是关于我无法通过curl登录该站点的主要内容,如果未能解决你的问题,请参考以下文章

如何从 Chrome 复制 cookie?

FTP 错误 530 用户无法登录

PHP Curl PUT 在 curl_exec 处停止

Elastic Beanstalk 上的 Tomcat 部署:无法访问该站点

无法通过使用 Volley 库中的 Intent 从片段中移动下一个 Activity

使用 auth 知道用户已登录