|
|
|
|
Strumenti |
10-12-2020, 10:17 | #1 |
Member
Iscritto dal: Jun 2020
Messaggi: 50
|
[PHP] Navigare sito con cURL, mi restituisce errore
Buongiorno!
Vorrei navigare su Facebook senza aprire un Browser, cioè: lanciando uno script php tramite curl vorrei fare l'autenticazione e poi andare su altre pagine. Ho trovato questo esempio per il "Primo Step" cioè l'autenticazione: Codice:
$fields = array( 'email' => '---email-fb---', 'pass' => '---password-fb---' ); $cookies = 'cookies.txt'; $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, 'https://m.facebook.com/login'); curl_setopt($ch, CURLOPT_HEADER, true); curl_setopt($ch, CURLOPT_USERAGENT, 'MozillaXYZ/1.0 Finto User-Agent'); curl_setopt($ch, CURLOPT_COOKIEJAR, $cookies); curl_setopt($ch, CURLOPT_COOKIEFILE, $cookies); curl_setopt($ch, CURLOPT_POST, true); curl_setopt($ch, CURLOPT_POSTFIELDS, $fields); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); $output = curl_exec($ch); curl_close($ch); echo $output; HTTP/2 302 pragma: no-cache location: https://m.facebook.com/checkpoint/?c...3Atrue%7D&_rdr cache-control: private, no-cache, no-store, must-revalidate expires: Sat, 01 Jan 2000 00:00:00 GMT set-cookie: locale=it_IT; expires=Thu, 17-Dec-2020 10:02:45 GMT; Max-Age=604800; path=/; domain=.facebook.com; secure strict-transport-security: max-age=15552000; preload; includeSubDomains x-content-type-options: nosniff content-type: text/html; charset=utf-8 x-xss-protection: 0 x-frame-options: DENY x-fb-debug: ECJt6w+a27vxNBskmhhsAliDr3Q9Wq9fVeo6XH9fDsJy5MpS2/ERQUnw3ZGvRRXrOU0bb/8PH7Ddui0CcmEApw== content-length: 0 date: Thu, 10 Dec 2020 10:02:48 GMT alt-svc: h3-29=":443"; ma=3600,h3-27=":443"; ma=3600 Avete un idea del motivo? |
10-12-2020, 19:52 | #2 |
Senior Member
Iscritto dal: Nov 2005
Messaggi: 2745
|
Quello che ti restituisce non è un errore. Quel "302" dopo HTTP/2 è lo Status Code e 302 è un redirect
https://developer.mozilla.org/en-US/...TTP/Status/302 In particolare è un redirect alla url indicata da location, specificato poco dopo. Dovresti fare una nuova richiesta GET a quella location, includendo anche i cookie perché è probabile che la prima richiesta abbia settato qualche cookie di sessione. |
11-12-2020, 07:58 | #3 | |
Member
Iscritto dal: Jun 2020
Messaggi: 50
|
Quote:
Codice:
$ch = curl_init(); curl_setopt($ch, CURLOPT_URL, 'https://m.facebook.com/login'); //--- curl_exec($ch); curl_setopt($ch, CURLOPT_URL, 'https://m.facebook.com/checkpoint/?checkpoint_data=......tutto il resto....&_rdr'); //--- $output = curl_exec($ch); curl_close($ch); echo $output; |
|
11-12-2020, 08:14 | #4 |
Senior Member
Iscritto dal: Nov 2005
Messaggi: 2745
|
Non sono molto ferrato di php ma guardando la documentazione ho visto che c'è un flag che puoi attivare nella prima richiesta per attivare il followup dei redirect, in questo modo credo che non ci sia bisogno di eseguire manualmente 2 request:
https://www.php.net/manual/en/function.curl-setopt.php vedi CURLOPT_FOLLOWLOCATION Se invece preferisci continuare manualmente penso tu debba estrarre location con curl_getinfo https://www.php.net/manual/en/function.curl-getinfo.php con l'option CURLINFO_REDIRECT_URL |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 23:58.