Curl Post - Longueur requise
-
21-12-2019 - |
Question
J'ai fait un code simple pour vous connecter à mon site Web.
private function request($url, $reset_cookies, $post_data)
{
$options = array(
CURLOPT_URL => $url,
CURLOPT_RETURNTRANSFER => 1,
CURLOPT_HEADER => 0,
CURLOPT_FAILONERROR => 1,
CURLOPT_USERAGENT => $this->user_agent,
CURLOPT_CONNECTTIMEOUT => 30,
CURLOPT_TIMEOUT => 30,
CURLOPT_SSL_VERIFYPEER => 0,
CURLOPT_FOLLOWLOCATION => 1,
CURLOPT_MAXREDIRS => 10,
CURLOPT_AUTOREFERER => 1,
CURLOPT_COOKIESESSION => $reset_cookies ? 1 : 0,
CURLOPT_COOKIEJAR => $this->session_id,
CURLOPT_COOKIEFILE => $this->session_id,
);
// Add POST data
if (isset($post_data))
{
$options[CURLOPT_CUSTOMREQUEST] = 'POST';
$options[CURLOPT_POST] = 1;
$options[CURLOPT_POSTFIELDS] = http_build_query($post_data);
}
// Attach options
curl_setopt_array($this->curl, $options);
// Execute the request and read the response
$content = curl_exec($this->curl);
// Handle any error
if (curl_errno($this->curl)) throw new Exception(curl_error($this->curl));
return $content;
}
Donc, fondamentalement, une étape normale pour mon système de connexion serait:
-
Envoyez une demande d'obtention de récupération du jeton de sécurité et d'initialiser une session de cookie.(Fait et fonctionnant)
$security_token = $this->browser->request('https://mysite.com/login', true, null);
-
Envoyez une demande postale avec le nom d'utilisateur, le mot de passe et le jeton de sécurité.
$postdata = array( 'login' => $login, 'password' => $password, '__RequestVerificationToken' => $security_token, ); $login_page = $this->browser->request('https://mysite.com/login', false, $postdata);
à l'étape 2, j'ai eu une erreur 411 disant que la longueur du contenu est requise.
ai-je fait quelque chose de mal ou ai-je oublié de définir un paramètre?
La solution
solution consistait à supprimer cette ligne
$options[CURLOPT_CUSTOMREQUEST] = 'POST';
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow