zoukankan      html  css  js  c++  java
  • Netscape HTTP Cooke File Parser In PHP

    http://www.hashbangcode.com/blog/netscape-http-cooke-file-parser-php

    I recently needed to create a function that would read and extract cookies from a Netscape HTTP cookie file. This file is generated by PHP when it runs CURL (with the appropriate options enabled) and can be used in subsequent CURL calls. This file can be read to see what cookies where created after CURL has finished running. As an example, this is the sort of file that might be created during a typical CURL call.

    # Netscape HTTP Cookie File
    # http://curl.haxx.se/rfc/cookie_spec.html
    # This file was generated by libcurl! Edit at your own risk.
     
    www.example.com        FALSE        /        FALSE        1338534278        cookiename        value

    The first few lines are comments and can therefore be ignored. The cookie data consists of the following items (in the order they appear in the file.

    • domain - The domain that created and that can read the variable.
    • flag - A TRUE/FALSE value indicating if all machines within a given domain can access the variable. This value is set automatically by the browser, depending on the value you set for domain.
    • path - The path within the domain that the variable is valid for.
    • secure - A TRUE/FALSE value indicating if a secure connection with the domain is needed to access the variable.
    • expiration - The UNIX time that the variable will expire on.
    • name - The name of the variable.
    • value - The value of the variable.

    So the function used to extract this information would look like this. It works in a pretty straightforward way and essentially returns an array of cookies found, if any. I originally tried to use a hash character to determine the start of a commented line and then try to extract anything else that had content. It turns out, however, that some sites will add cookies with a hash character at the start (yes, even for the URL parameter). So it is safer to detect for a cookie line by seeing if there are 6 tab characters in it. This is then exploded by the tab character and converted into an array of data items.

    /**
     * Extract any cookies found from the cookie file. This function expects to get
     * a string containing the contents of the cookie file which it will then
     * attempt to extract and return any cookies found within.
     *
     * @param string $string The contents of the cookie file.
     * 
     * @return array The array of cookies as extracted from the string.
     *
     */
    function extractCookies($string) {
        $cookies = array();
        
        $lines = explode("
    ", $string);
     
        // iterate over lines
        foreach ($lines as $line) {
     
            // we only care for valid cookie def lines
            if (isset($line[0]) && substr_count($line, "	") == 6) {
     
                // get tokens in an array
                $tokens = explode("	", $line);
     
                // trim the tokens
                $tokens = array_map('trim', $tokens);
     
                $cookie = array();
     
                // Extract the data
                $cookie['domain'] = $tokens[0];
                $cookie['flag'] = $tokens[1];
                $cookie['path'] = $tokens[2];
                $cookie['secure'] = $tokens[3];
     
                // Convert date to a readable format
                $cookie['expiration'] = date('Y-m-d h:i:s', $tokens[4]);
     
                $cookie['name'] = $tokens[5];
                $cookie['value'] = $tokens[6];
     
                // Record the cookie.
                $cookies[] = $cookie;
            }
        }
        
        return $cookies;
    }

    To test this function I used the following code. This takes a URL (google.com in this case) and sets up the options for CURL so that when the page is downloaded it also creates a cookie file. This file is then analyzed using the above function to see what cookies are present therein.

    // Url to extract cookies from
    $url = 'http://www.google.com/';
     
    // Create a cookiefar file
    $cookiefile = tempnam("/tmp", "CURLCOOKIE");
     
    // create a new cURL resource
    $curl = curl_init();
     
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
     
    // Set user agent
    curl_setopt($curl, CURLOPT_USERAGENT, "Mozilla/5.0 (X11; U; Linux x86_64; en-US; rv:1.9.1.3) Gecko/20090910 Ubuntu/9.04 (jaunty) Shiretoko/3.5.3");
     
    // set URL and other appropriate options
    curl_setopt($curl, CURLOPT_URL, $url);
    curl_setopt($curl, CURLOPT_HEADER, true);
     
    curl_setopt($curl, CURLOPT_COOKIEJAR, $cookiefile);
     
    $data = curl_exec($curl);
     
    // close cURL resource, and free up system resources
    curl_close($curl);
     
    // Extract and store any cookies found
    print_r(extractCookies(file_get_contents($cookiefile)));

    When run, this function produces the following output.

    Array
    (
        [0] => Array
            (
                [domain] => .google.com
                [flag] => TRUE
                [path] => /
                [secure] => FALSE
                [expiration] => 2013-06-29 10:00:01
                [name] => PREF
                [value] => ID=051f529ee8937fc5:FF=0:TM=1309424401:LM=1309424401:S=4rhYyPL_bW9KxVHI
            )
     
    )
  • 相关阅读:
    基于 Docker 的 MySQL 主从复制搭建
    获取 Docker 容器的 IP 地址
    Maven 学习资料
    docker 中,修改了 mysql 配置,如何重启 mysql?
    TiDB 学习资料
    Sharding-JDBC 学习资料
    Druid(数据库连接池) 学习资料
    JWT 学习资料
    Maven 拥有三套相互独立的生命周期:clean、default、site
    Maven 生命周期的阶段与插件的目标之间的绑定关系
  • 原文地址:https://www.cnblogs.com/goldenstones/p/6061397.html
Copyright © 2011-2022 走看看