【问题标题】:Decode Cookie variable extracted from a HTTP Stream - Python解码从 HTTP 流中提取的 Cookie 变量 - Python
【发布时间】:2012-08-15 22:25:24
【问题描述】:

我正在使用 python 向服务器发送请求。我从服务器得到一个 cookie。我正在尝试解码服务器使用的编码方案 - 我怀疑它是 utf-8 或 base64。 所以我创建了我的标头和连接对象。

resp, content = httpobj.request(server, 'POST', headers=HTTPheader, body=HTTPbody)

然后我从 HTTP 流中提取 cookie

cookie= resp['set-cookie']

我尝试了str.decode()unicode(),但我无法获取 cookie 的解压内容。

假设 cookie 是

MjAyMTNiZWE4ZmYxYTMwOVPJ7Jh0B%2BMUcE4si5oDcH7nKo4kAI8CMYgKqn6yXpgtXOSGs8J9gm20bgSlYMUJC5rmiQ1Ch5nUUlQEQNmrsy5LDgAuuidQaZJE5z%2BFqAJPnlJaAqG2Fvvk5ish%3%3%

我期待的输出是

20213bea8ff1a309SÉì˜tLQÁ8².hÁûœª8<Æ *©úÉzµs’Ïö¶Ñ¸•ƒ$.kš$5gQIPf®Ì¹,8ºèA¦IœöZ€$ùå% *ao¾Nb²¶ÁöÃ

【问题讨论】:

    标签: python http cookies utf-8 base64


    【解决方案1】:

    试试这样:

    import urllib
    import base64
    
    cookie_val = """MjAyMTNiZWE4ZmYxYTMwOVPJ7Jh0B%2BMUcE4si5oDcH7nKo4kAI8CMYgKqn6yXpgtXOSGs8J9gm20bgSlYMUJC5rmiQ1Ch5nUUlQEQNmrsy5LDgAuuidQaZJE5z%2BFqAJPnlJaAqG2Fvvk5ishG%2FsH%2FA%3D%3D"""
    
    res =  base64.b64decode(urllib.unquote(cookie_val))
    
    print repr(res)
    

    输出:

    "20213bea8ff1a309S\xc9\xec\x98t\x07\xe3\x14pN,\x8b\x9a\x03p~\xe7*\x8e$\x00\x8f\x021\x88\n\xaa~\xb2^\x98-\\\xe4\x86\xb3\xc2}\x82m\xb4n\x04\xa5`\xc5\t\x0b\x9a\xe6\x89\rB\x87\x99\xd4RT\x04@\xd9\xab\xb3.K\x0e\x00.\xba'Pi\x92D\xe7?\x85\xa8\x02O\x9eRZ\x02\xa1\xb6\x16\xfb\xe4\xe6+!\x1b\xfb\x07\xfc"
    

    当然这里的结果是一个8位的字符串,所以你必须对它进行解码才能得到你想要的字符串,我不确定使用哪种编码,但是有使用unicode的解码结果-转义(unicode 文字):

    >>> print unicode(res, 'unicode-escape') 
    20213bea8ff1a309SÉìtãpN,p~ç*$1ª~²^-\ä³Â}m´n¥`ÅBÔRT@Ù«³.K.º'PiDç?¨ORZ¡¶ûäæ+!ûü
    

    希望这能有所帮助。

    【讨论】:

    • 感谢您的帮助。我唯一需要弄清楚的是如何将它作为十六进制整数值传递给函数。我正在尝试实现Padding Oracle 算法
    猜你喜欢
    • 1970-01-01
    • 2013-05-29
    • 2020-09-19
    • 1970-01-01
    • 2015-04-30
    • 2022-01-20
    • 2015-09-09
    • 2021-12-01
    • 2021-04-28
    相关资源
    最近更新 更多