4

認証Cookieをファイルに保存するために、この回答に基づいて以下のコードを使用しています。これにより、プログラムを実行するたびにログインする必要がなくなります。

現在、通常のセッション Cookie からcsrftokencsrf = s.cookies['csrftoken']を取得することはうまく機能しますが、を使用して cookiejar から取得しようとすると、

AttributeError: LWPCookieJar instance has no attribute '__getitem__'`

s.cookies は現在 LWPCookieJar オブジェクトですが、リストとして扱っているため、これが発生することを理解しています。これにより、2つのオプションが残ると思います。

また:

  • オブジェクトからリストを抽出しLWPCookieJar、csrf トークンを取得するのは簡単です。
  • または、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 に答える