So melden Sie sich mit Curl und SSL und Cookies an
Ich habe versucht, mich mit curl auf der mobilen Website barnesandnoble.com einzuloggen und hatte bisher kein Glück. Ich erhalte die Seite ohne Fehler zurück und meine E-Mail wird standardmäßig wieder in das E-Mail-Eingabeformularfeld der Anmeldeseite eingegeben (in dem Formular, das von print $ result zurückgegeben wurde).
Mit dem gleichen Code kann ich tatsächlich korrekt zu ebay wechseln, indem ich die LOGINURL so ändere, dass sie auf den Login von ebay verweist
Der einzige Unterschied ist, dass barnesandnobles https: // und ebay login http: // war
Außerdem glaube ich, dass die barnes-Website asp / aspx ist, daher weiß ich nicht, wie das mit Cookies und _state anders umgehen würde
Für jede Hilfe wäre ich dankbar, da ich in den letzten 16 Stunden versucht habe, dieses Problem zu beheben
Außerdem ist meine cookie.txt beschreibbar und funktioniert
<code><?php $cookie_file_path = "C:/test/cookie.txt"; $LOGINURL = "https://cart2.barnesandnoble.com/mobileacct/op.asp?stage=signIn"; $agent = "Nokia-Communicator-WWW-Browser/2.0 (Geos 3.0 Nokia-9000i)"; $ch = curl_init(); $headers[] = "Accept: */*"; $headers[] = "Connection: Keep-Alive"; $headers[] = "Content-type: application/x-www-form-urlencoded;charset=UTF-8"; curl_setopt($ch, CURLOPT_HTTPHEADER, $headers); curl_setopt($ch, CURLOPT_HEADER, 0); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_URL, $LOGINURL); curl_setopt($ch, CURLOPT_USERAGENT, $agent); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_file_path); curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_file_path); $content = curl_exec($ch); curl_close($ch); unset($ch); // NAME="path_state" value="6657403"> if(stristr($content,"path_state")){ $array1 = explode('path_state" value="',$content); $content1 = $array1[1]; $array2 = explode('">',$content1); $content2 = $array2[0]; } $LOGINURL = "https://cart2.barnesandnoble.com/mobileacct/op.asp?stage=signIn"; $POSTFIELDS = "d_hidPageStamp=V_3_17&hidViewMode=opSignIn&stage=signIn&previousStage=mainStage&path_state=" . $content2 . "&[email protected]&acctPassword=YOURPASSWORD"; $reffer = "https://cart2.barnesandnoble.com/mobileacct/op.asp?stage=signIn"; $ch = curl_init(); $headers[] = "Accept: */*"; $headers[] = "Connection: Keep-Alive"; $headers[] = "Content-type: application/x-www-form-urlencoded;charset=UTF-8"; curl_setopt($ch, CURLOPT_HTTPHEADER, $headers); curl_setopt($ch, CURLOPT_HEADER, 0); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_URL, $LOGINURL); curl_setopt($ch, CURLOPT_USERAGENT, $agent); curl_setopt($ch, CURLOPT_POST, 1); curl_setopt($ch, CURLOPT_POSTFIELDS, $POSTFIELDS); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); curl_setopt($ch, CURLOPT_REFERER, $reffer); curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_file_path); curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_file_path); $result = curl_exec($ch); print $result; ?> </code>