|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
由于豆瓣登录的维护更新,小甲鱼原来的答案已经不能使用了,我参考一位鱼油发的代码,代码如下:
import urllib.request
from http.cookiejar import CookieJar
import json
# 豆瓣的登录url
loginurl = 'https://accounts.douban.com/j/mobile/login/basic'
cookie = CookieJar()
opener = urllib.request.build_opener(urllib.request.HTTPCookieProcessor(cookie))
headers={"User-Agent":"Mozilla/5.0 (Windows NT 10.0; WOW64) \
AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.132 \
Safari/537.36"}
data = {
"ck":"",
"name":"这里填邮箱",
"password":"这里填密码",
"remember":"false",
"ticket":""
}
req = urllib.request.Request(loginurl,urllib.parse.urlencode(data).\
encode('utf-8'),headers)
res = opener.open(req)
res_html = res.read().decode('utf-8')
res_js = json.loads(res_html)
if res_js['status'] == 'success':
print('登录成功')
else:
print('登录失败')
输入正确的邮箱密码,运行后登录失败,返回的json显示参数缺失
{"status":"failed","message":"parameter_missing","description":"参数缺失","payload":{}}
麻烦解答一下,求求了!
试试requests吧,免去设置cookie。
- import requests
- url = 'https://accounts.douban.com/j/mobile/login/basic'
- headers = {'user-agent': 'firefox'}
- data = {
- "ck": "",
- "name": "邮箱",
- "password": "密码",
- "remember": "false",
- "ticket": ""
- }
- s = requests.session()
- r1 = s.get(url=url, headers=headers)
- r2 = s.post(url=url, headers=headers, data=data)
- print(r2.text)
复制代码
|
|