鱼C论坛

 找回密码
 立即注册
查看: 5654|回复: 8

[已解决]python54讲,豆瓣登录问题

[复制链接]
发表于 2020-5-22 20:24:49 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

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":{}}
麻烦解答一下,求求了!
最佳答案
2020-5-23 01:06:35
试试requests吧,免去设置cookie。
  1. import requests

  2. url = 'https://accounts.douban.com/j/mobile/login/basic'
  3. headers = {'user-agent': 'firefox'}
  4. data = {
  5.     "ck": "",
  6.     "name": "邮箱",
  7.     "password": "密码",
  8.     "remember": "false",
  9.     "ticket": ""
  10. }
  11. s = requests.session()
  12. r1 = s.get(url=url, headers=headers)
  13. r2 = s.post(url=url, headers=headers, data=data)
  14. print(r2.text)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-5-23 01:06:35 | 显示全部楼层    本楼为最佳答案   
试试requests吧,免去设置cookie。
  1. import requests

  2. url = 'https://accounts.douban.com/j/mobile/login/basic'
  3. headers = {'user-agent': 'firefox'}
  4. data = {
  5.     "ck": "",
  6.     "name": "邮箱",
  7.     "password": "密码",
  8.     "remember": "false",
  9.     "ticket": ""
  10. }
  11. s = requests.session()
  12. r1 = s.get(url=url, headers=headers)
  13. r2 = s.post(url=url, headers=headers, data=data)
  14. print(r2.text)
复制代码

评分

参与人数 1荣誉 +3 鱼币 +3 贡献 +3 收起 理由
无锋 + 3 + 3 + 3

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 2 反对 0

使用道具 举报

 楼主| 发表于 2020-5-23 16:53:31 | 显示全部楼层
suchocolate 发表于 2020-5-23 01:06
试试requests吧,免去设置cookie。

用你的代码成功了,谢谢啦!受你的这一句代码"r1 = s.get(url=url, headers=headers)"启发,我找到问题所在了,需要先用get方式请求一次,再向登录的url传参,代码修改如下:
  1. import urllib.request
  2. from http.cookiejar import CookieJar
  3. import json

  4. # 豆瓣的登录url
  5. loginurl = 'https://accounts.douban.com/j/mobile/login/basic'
  6. # 豆瓣首页url
  7. url = 'https://www.douban.com/'
  8. # 定制opener,传递cookie
  9. cookie = CookieJar()
  10. opener = urllib.request.build_opener(urllib.request.HTTPCookieProcessor(cookie))
  11. # 设置headers
  12. headers={'User-Agent':'Mozilla/5.0 (Windows NT 10.0; WOW64) \
  13.          AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.132 \
  14.          Safari/537.36'}
  15. # 表单提交参数设置
  16. data = {
  17. 'ck':'',
  18. 'name':'这里填邮箱~QAQ',
  19. 'password':'这里填密码~QAQ',
  20. 'remember':'false',
  21. 'ticket':''
  22. }
  23. # get请求的request
  24. req_get = urllib.request.Request(url,headers=headers)
  25. # post请求的request
  26. req_post = urllib.request.Request(loginurl,urllib.parse.urlencode(data).\
  27.                              encode('utf-8'),headers)
  28. # get请求的response
  29. res_get = opener.open(req_get)
  30. # post请求的response
  31. res_post = opener.open(req_post)

  32. res_html = res_post.read().decode('utf-8')

  33. # json解码
  34. res_js = json.loads(res_html)
  35. # 根据status的值判断是否登录成功
  36. if res_js['status'] == 'success':
  37.     print('登录成功')
  38. else:
  39.     print('登录失败')
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2020-5-31 10:42:20 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-8-11 21:00:16 | 显示全部楼层
无锋 发表于 2020-5-23 16:53
用你的代码成功了,谢谢啦!受你的这一句代码"r1 = s.get(url=url, headers=headers)"启发,我找到问题所 ...

还是登录失败orz
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-15 09:38:34 | 显示全部楼层
无锋 发表于 2020-5-23 16:53
用你的代码成功了,谢谢啦!受你的这一句代码"r1 = s.get(url=url, headers=headers)"启发,我找到问题所 ...

不要需要用两次请求,参数缺失是因为 headers 中缺少 referer,添加这个参数就可以了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 0 反对 2

使用道具 举报

发表于 2020-11-15 09:39:17 | 显示全部楼层
无锋 发表于 2020-5-23 16:53
用你的代码成功了,谢谢啦!受你的这一句代码"r1 = s.get(url=url, headers=headers)"启发,我找到问题所 ...

不要需要用两次请求,参数缺失是因为 headers 中缺少 referer,添加这个参数就可以了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-6-20 08:06:03 | 显示全部楼层
suchocolate 发表于 2020-5-23 01:06
试试requests吧,免去设置cookie。

请问这样怎么破
  1. {"status":"failed","message":"captcha_required","description":"需要图形验证码","payload":{"tc_app_id":"2044348370","captcha_signature_sample":"12:1,28:2","touch_cap_url":"https:\/\/ssl.captcha.qq.com\/TCaptcha.js","captcha_id":"login:captcha:B6UGW44lW8O9NATmd9op7Jrh","captcha_image_url":"https:\/\/accounts.douban.com\/j\/captcha\/show?vid=login:captcha:B6UGW44lW8O9NATmd9op7Jrh&size=small"}}
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-9-8 17:55:27 | 显示全部楼层
还是失败
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-26 21:35

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表