4

我正在使用基于此答案的以下代码将身份验证 cookie 存储在文件中。这使我可以避免每次运行程序时都必须登录。

现在,从常规 Session cookie 中获取csrftoken效果很好,但是当我尝试使用 cookiejar 从 cookiejar 中获取它时csrf = s.cookies['csrftoken'],我得到了

AttributeError: LWPCookieJar instance has no attribute '__getitem__'`

我知道发生这种情况是因为我将 s.cookies 视为一个列表,即使它现在是一个 LWPCookieJar 对象。我想这给我留下了两个选择:

任何一个:

  • LWPCookieJar对象中提取列表,然后获取 csrf 令牌很容易。
  • 或者,找到适当的语法以直接从LWPCookieJar.

我怎样才能做到这一点?


import os
import requests
from cookielib import LWPCookieJar

s = requests.Session()
s.cookies = LWPCookieJar('cookiejar')
if os.path.exists('cookiejar'):
    # Load saved cookies from the file and use them in a request
    print('loading saved cookies')
    s.cookies.load()        
else:
    # Create a new cookies file and set our Session's cookies
    print('saving cookies')
    s.cookies.save()
r = s.get('http://httpbin.org/cookies')
print(r.text)
# Save the session's cookies back to the file
s.cookies.save()
4

1 回答 1

0

我终于弄明白了。不确定是否可以进一步简化。

import os, requests
from cookielib import LWPCookieJar

def login():
    global s
    s = requests.Session()
    if os.path.exists('cookiejar'):
        print('Cookies exist! Fast login.\r'),
        global csrf
        with open('cookiejar') as f:
            s.cookies = requests.utils.cookiejar_from_dict(pickle.load(f))
        csrf = s.cookies['csrftoken']
        print('csrf: {0}').format(csrf) # Debug information
    else:
        print('Cookies do not exist. Slow login.\r'),
        s.get('http://www.example.com/') # to get csrf
        csrf = s.cookies['csrftoken']
        data= dict(csrftoken=csrf, username="user", password="pass")
        s.post('https://www.example.com/login/', data=data, headers=headers)
        with open('cookiejar', 'w') as f:
            pickle.dump(requests.utils.dict_from_cookiejar(s.cookies), f)
于 2014-12-08T20:53:59.697 回答