TryPyPy's answer меня на правильном пути, но код в связанном рецепт устарел и не будет работать с Python3. Вот Python3 код, который будет читать куков от запущенного Firefox и использовать его при запросе веб-страницы:
import requests
url = 'http://github.com'
cookie_file = '/home/user/.mozilla/firefox/f00b4r.default/cookies.sqlite'
def get_cookie_jar(filename):
"""
Protocol implementation for handling gsocmentors.com transactions
Author: Noah Fontes nfontes AT cynigram DOT com
License: MIT
Original: http://blog.mithis.net/archives/python/90-firefox3-cookies-in-python
Ported to Python 3 by Dotan Cohen
"""
from io import StringIO
import http.cookiejar
import sqlite3
con = sqlite3.connect(filename)
cur = con.cursor()
cur.execute("SELECT host, path, isSecure, expiry, name, value FROM moz_cookies")
ftstr = ["FALSE","TRUE"]
s = StringIO()
s.write("""\
# Netscape HTTP Cookie File
# http://www.netscape.com/newsref/std/cookie_spec.html
# This is a generated file! Do not edit.
""")
for item in cur.fetchall():
s.write("%s\t%s\t%s\t%s\t%s\t%s\t%s\n" % (
item[0], ftstr[item[0].startswith('.')], item[1],
ftstr[item[2]], item[3], item[4], item[5]))
s.seek(0)
cookie_jar = http.cookiejar.MozillaCookieJar()
cookie_jar._really_load(s, '', True, True)
return cookie_jar
cj = get_cookie_jar(cookie_file)
response = requests.get(url, cookies=cj)
print(response.text)
Испытано на Kubuntu Linux 14.10 с Python 3.4.2 и Firefox 39.0. Код также доступен от my Github repo.
Спасибо за ответ! Есть ли пример использования механизации для получения файлов cookie браузера? Я видел пример в документации для старого файла cookie.txt, но не для нового файла cookie.sqlite. – Hempage
Мне удалось найти это раннее объяснение: http://osdir.com/ml/python.wwwsearch.general/2008-02/msg00012.html – TryPyPy
Попытка механизировать совсем немного, мне не повезло ... Но после используя рецепт, с которым вы связались, у меня был большой успех. – Hempage