模拟登陆,提示登陆成功,但是再发请求还是没登陆( requests)

2016-01-18 12:20:30 +08:00
 Darek
import json

def doit(email,encrypted_password):
s = requests.Session()
#登陆
logininfo = {'encrypted_password':encrypted_password,'remember_me':'true','email':email}
login = s.post('http://geeklab.cc/users/sessions/auth',data=logininfo)
print(login.status_code) #200
print(login.text) #{"status":0,"code":1,"msg":"登陆成功","url":"/assignments"}



#获取任务列表
jobList = s.get('http://geeklab.cc/assignments/fresh?page=1')

print(jobList.status_code) # 200 (如果是正常返回 json 因该是 304 )

jobListJson = json.loads(jobList.text)
info = jobListJson['assignments']

print(info)

研究好久不知道问题出在哪里了
2925 次点击
所在节点    Python
13 条回复
zzxa
2016-01-18 12:26:06 +08:00
jiashang cookie
bobuick
2016-01-18 12:31:58 +08:00
上 django 么
session 的 middleware 加进 setting 了么
codepark
2016-01-18 12:33:00 +08:00
headers = {'Cookie':x['set-cookie'].split(';')[0],'Content-Type':'application/json'}
Darek
2016-01-18 13:16:14 +08:00
@bobuick 问题在 X-CSRF-Token 这里么?才学 Python ,不太懂
just1
2016-01-18 13:21:32 +08:00
@Darek cookie 以及其他类似 x-csrf-token 的防止机器人的参数。建议去看看基础案例(比如爬虫)
bobuick
2016-01-18 13:29:39 +08:00
@bobuick 没事, 看错了。以为你是在说服务端。
这个是 cookie 的事
neo2015
2016-01-18 13:29:53 +08:00
加 cookie
Darek
2016-01-18 13:39:13 +08:00
@zzxa @bobuick @neo2015

用了 requests.Session() 了,在同一个 Session 实例发出的所有请求之间保持 cookies 。
zzxa
2016-01-18 15:48:45 +08:00
master13
2016-01-18 15:54:56 +08:00
类似的问题我喜欢抓包和浏览器的抓包一行一行的比较,一定能发现问题呢
tempdban
2016-01-18 23:17:20 +08:00
useragent 啊哥 requests 库默认 ua 很奇怪的 你改一下
fy
2016-01-19 14:57:26 +08:00
@zzxa 没有用过不要误导别人, Session 会自动保持 cookies
zzxa
2016-01-19 18:58:33 +08:00
@fy 我不会 python ,但我的代码里这么写就能运行~

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/251537

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX