普通文本  |  31行  |  1.01 KB

import os, random


def unique_id(cookie_key):
    """
    Find out if remote caller has cookie set on the key.
    If not, set cookie on client side: evaluate this key by a random string.
    ( unique user identifier )
    In both scenarios return value of the cookie, be it old or newly set one
    """
    uid = ''
    ## try to retrieve uid from Cookie
    if 'HTTP_COOKIE' in os.environ:
        ## parse os.environ['HTTP_COOKIE']
        cookies = os.environ['HTTP_COOKIE'].split(';')
        key = '%s=' % cookie_key
        uid_cookies = [c for c in cookies if c.strip().startswith(key)]

        if uid_cookies:
            assert(len(uid_cookies) == 1)
            uid_cookie = uid_cookies[0]
            uid = uid_cookie.replace(key, '')

    if not uid:
        uid = str(random.random())[2:16] # random string of 14 digits
        set_cookie_statement = 'Set-Cookie:%s=%s;' % (cookie_key, uid)
        set_cookie_statement += 'expires=Thu, 26-Dec-2013 22:03:25 GMT;'
        print set_cookie_statement

    return uid