cUrl verliert Session?

Einklappen
X
 
  • Filter
  • Zeit
  • Anzeigen
Alles löschen
neue Beiträge

  • cUrl verliert Session?

    Hallo,

    ich möchte automatisiert bei dem Bookmark-Dienst alltagz.de ein Bookmark setzen. Ich nutze dafür cURL.

    Das Einloggen klappt ohne Probleme, nach dem Login mit cUrl lande ich auf der Startseite des internen Bereichs. cUrl setzt auch in der cookie.txt ein Session-Cookie. Wenn ich jetzt erneut ein POST (in der gleichen Domain, aber andere URL) absetze um ein Bookmark einzutragen, bin ich sofort wieder ausgeloggt. Ich teste jetzt schon einige Zeit, studiere Request Header und Response Header, scheint alles in Ordnung zu sein.

    Jetzt lasse ich mir mal den Response-Header beider Abfrage mit ausgeben, und sie da, bei Set-Cookie wird bei beiden Requests jeweils eine andere Session-ID gesetzt. Also irgendwas ist hier faul, ich finde aber leider den Grund nicht. Habt ihr da eine Idee.

    Der ganze Code funktioniert z.B. aber bei Mister Wong ohne Probleme, dort bleib ich eingeloggt und kann mein Bookmark speichern!

    Die Debug-Ausgaben als Kommentare zeigen, wo ich meine Debug-Tests gemacht habe

    Sieht jemand irgendwo noch ein Problem, und weiß warum die Session verloren geht?

    Theoretisch sollte ich nach dem Login ja eingeloggt bleiben, aber irgendwie macht das Curl hier nicht!

    Danke!
    PHP-Code:
    <?php
    class bookmark {

        
    /**
         * Constructor
         */
        
    function __construct() {
        }

        
    /**
         * Destructor
         */
        
    function __destruct() {
        }

        
    /**
         * Send post request
         * @param string $strUrl Url
         * @param string $strParameter Parameters
         * @return string Result content
         */
        
    protected function bookmark_post($strUrl,$strParameter) {
            
    $objCUrl curl_init();
            
    curl_setopt($objCUrlCURLOPT_URL$strUrl);
            
    curl_setopt($objCUrlCURLOPT_COOKIESESSIONtrue);
            
    curl_setopt($objCUrlCURLOPT_COOKIEFILE'/var/www/domain/cookie.txt');
            
    curl_setopt($objCUrlCURLOPT_COOKIEJAR,  '/var/www/domain/cookie.txt');
            
    curl_setopt($objCUrlCURLOPT_POST ,true);
            
    curl_setopt($objCUrlCURLOPT_POSTFIELDS$strParameter);        
            
    curl_setopt($objCUrlCURLOPT_FOLLOWLOCATIONtrue);
            
    curl_setopt($objCUrlCURLOPT_VERBOSEfalse);
            
    curl_setopt($objCUrlCURLOPT_HEADERtrue);
            
    curl_setopt($objCUrlCURLOPT_RETURNTRANSFERtrue);
            
    curl_setopt($objCUrlCURLOPT_HTTP_VERSIONCURL_HTTP_VERSION_1_1);
            
    curl_setopt($objCUrlCURLOPT_TIMEOUT10);
            
    $strResult curl_exec($objCUrl);
            if (
    curl_error($objCUrl)) {
                return 
    null;
            }       
            
    curl_close($objCUrl);     
            return 
    $strResult;
        } 

        
    /**
         * Add bookmark to alltagz.de
         * @param string $strUsername Login username
         * @param string $strPassword Login password
         * @param string $strSiteUrl Site url
         * @param string $strSiteTitle Site title
         * @param string $strSiteDescription Site description
         * @param string $strSiteTags Site tags
         * @return boolean
         */
        
    public function bookmark_alltagzDe($strUsername,$strPassword,$strSiteUrl,$strSiteTitle,$strSiteDescription,$strSiteTags) {
            
    $strUrl 'http://www.alltagz.de/login/';
            
    $strParameter 'query=&username='.$strUsername.'&password='.$strPassword.'&submitted=Login';
            
    // Login
            
    if ($strResult $this->bookmark_post($strUrl,$strParameter)) {
                
    // echo $strResult; exit; // <- DEBUG AUSGABE: STARTSEITE NACH LOGIN - FUNKTIONIERT!!!
                // Add url
                
    $strUrl 'http://www.alltagz.de/bookmarks/username';
                
    $strParameter 'address='.$strSiteUrl;
                
    $strParameter.= '&title='.utf8_encode($strSiteTitle);
                
    $strParameter.= '&description='.utf8_encode($strSiteDescription);
                
    $strParameter.= '&tags='.utf8_encode($strSiteTags);
                
    $strParameter.= '&topic=0';
                
    $strParameter.= '&status=0';
                
    $strParameter.= '&submitted=Favorit hinzufügen';
                if (
    $strResult $this->bookmark_post($strUrl,$strParameter)) {
                    
    // echo $strResult; exit; // <- DEBUG AUSGABE: SEITE NACH SPEICHERN DES BOOKMARK - FUNKTIONIERT NICHT => AUSGELOGGT!!!
                
    } else {
                    return 
    false;
                }
            } 
            return 
    false;            
        }           
               
    }
    ?>
    Hier mal noch die beiden Response-Header, wo eigentlich die Session-ID gleich sein sollte:
    Code:
    Array
    (
        [0] => HTTP/1.1 302 Found
        [1] => Date: Sat, 07 Aug 2010 16:18:59 GMT
        [2] => Server: Apache/2.2.9 (Debian) DAV/2 SVN/1.5.1 mod_fastcgi/2.4.2 PHP/5.2.6-1+lenny3 with Suhosin-Patch mod_python/3.3.1 Python/2.5.2
        [3] => X-Powered-By: PHP/5.2.6-1+lenny3
        [4] => Set-Cookie: PHPSESSID=e0d70b203e42c35c5a327f7007ebca61; path=/
        [5] => Expires: Thu, 19 Nov 1981 08:52:00 GMT
        [6] => Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0
        [7] => Pragma: no-cache
        [8] => Location: /bookmarks/username
        [9] => Vary: Accept-Encoding
        [10] => Content-Length: 0
        [11] => Content-Type: text/html; charset=UTF-8
    )
    
    Array
    (
        [0] => HTTP/1.1 200 OK
        [1] => Date: Sat, 07 Aug 2010 16:18:59 GMT
        [2] => Server: Apache/2.2.9 (Debian) DAV/2 SVN/1.5.1 mod_fastcgi/2.4.2 PHP/5.2.6-1+lenny3 with Suhosin-Patch mod_python/3.3.1 Python/2.5.2
        [3] => X-Powered-By: PHP/5.2.6-1+lenny3
        [4] => Set-Cookie: PHPSESSID=28f4370bb2702bdf7bbaba40e704493f; path=/
        [5] => Expires: Thu, 19 Nov 1981 08:52:00 GMT
        [6] => Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0
        [7] => Pragma: no-cache
        [8] => Vary: Accept-Encoding
        [9] => Transfer-Encoding: chunked
        [10] => Content-Type: text/html; charset=utf-8
    )
    Zuletzt geändert von TriphunEM; 07.08.2010, 17:30.

  • #2
    Probier' mal, die Cookie-Optionen als erstes zu setzen, vor den Post-Dingern ... bin erst letztens einem Fall über den Weg gelaufen, wo die Reihenfolge sich ausgewirkt hat.
    I don't believe in rebirth. Actually, I never did in my whole lives.

    Kommentar


    • #3
      Hallo, danke. Aber das hat leider keine Auswirkungen. Irgendwas ist anders als z.B. bei Mister Wong, aber ich finde nicht raus was!

      Kommentar


      • #4
        Hallo,

        Zitat von http://de.php.net/manual/de/function.curl-setopt.php
        CURLOPT_COOKIESESSION TRUE um diesen Request als neue "Cookie Session" zu behandeln. Somit wird libcurl alle cookies die geladen werden sollen ignorieren, sofern es sich um "Session Cookies" einer vorherigen Session handelt. Standardmässig lädt und speichert libcurl alle cookies, unabhängig davon, ob es "Session Cookies" sind. Bei "Session Cookies" handelt es sich um Cookies ohne Ablaufdatum, die nur für die aktuelle Session gültig sind.


        Gruß,

        Amica
        [COLOR="DarkSlateGray"]Hast du die [COLOR="DarkSlateGray"]Grundlagen zur Fehlersuche[/color] gelesen? Hast du Code-Tags benutzt?
        Hast du als URL oder Domain-Beispiele example.com, example.net oder example.org benutzt?
        Super, danke!
        [/COLOR]

        Kommentar


        • #5
          *lol* Danke! Das war's...

          Kommentar

          Lädt...
          X