我正在尝试制作一个工具,以获得某人需要工作的时间。登录是使用 CSRF 令牌保护的,因此我需要先获取它,然后才能登录。
这是我目前使用的脚本:
<?php
error_reporting(E_ALL);
ini_set('display_errors', 1);
$username = "jules.kreutzer";
$password = "jules";
$url = "planner.a-mac.nl";
$cookie= "koekje.txt";
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_COOKIEJAR, '/tmp/'.$cookie);
curl_setopt($ch, CURLOPT_COOKIEFILE, '/tmp/'.$cookie);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$response = curl_exec($ch);
if (curl_errno($ch)) die(curl_error($ch));
$doc = new DOMDocument();
$doc->loadHTML("http://planner.a-mac.nl");
$token = $doc->getElementByID("signin__csrf_token")->attributes->getNamedItem("value")->value;
print_r($token);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, false);
curl_setopt($ch, CURLOPT_POST, true);
$params = array(
'signin[username]' => $username,
'signin[password]' => $password,
'signin[_csrf_token]' => $token
);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($params));
curl_exec($ch);
if (curl_errno($ch)) print curl_error($ch);
curl_close($ch);
?>
当我在Web浏览器中加载此代码时,出现以下错误:
注意:尝试获取非对象的属性 /Applications/MAMP/htdocs/test.php 在第 22 行
致命错误:在 null 上调用成员函数 getNamedItem() /Applications/MAMP/htdocs/test.php 在第 22 行
第 22 行是:
$token = $doc->getElementByID("signin__csrf_token")->attributes->getNamedItem("value")->value;
我希望有人可以帮助我获得令牌,以便我可以使用它进行登录。
你拼错了getElementById:
改变:
$token = $doc->getElementByID("signin__csrf_token")->attributes->getNamedItem("value")->value;
自:
$token = $doc->getElementById("signin__csrf_token")->attributes->getNamedItem("value")->value;