HTTP协议无状态,书面点的说法是指协议对于交互性场景没有记忆功能,直白点的说,就是HTTP刷新后,不记得你之前做了什么设置,通常要解决cookie记录登录状态的方法有以下几种:
1.直接把用户名和密码保持到cookie中,不过目前此类方法风险比较大,一般不把密码等重要信息保存到Cookie中。
2.把密码加密后保存到Cookie中,下次访问时解密并与数据库比较。
3.加密账号后连同账号一块保存到Cookie中。
4.利用session会话将cookies等值自动传到下一个接口。Session相当于程序在服务器上建立的一份客户档案,客户来访的时候只需要查询客户档案表就可以了。
手动传cookies有一定的繁琐:
importrequests# 登录接口log_url="http://shopxo.hctestedu.com/index.php?s=/index/user/login.html"# 登录参灵敏data= {"accounts": "longge", "pwd": "888888"} # 头部信息head= {"X-Requested-With": "XMLHttpRequest"} login_response=requests.post(log_url, data=data, headers=head) # 获取cookie,传给下面订单接口cookie=login_response.cookies# 订单接口order_url="http://shopxo.hctestedu.com/index.php?s=/index/cart/index.html"order_response=requests.get(order_url, cookies=cookie) print(order_response.text)
不过我们也可以尝试session会话管理,订单接口自动带上cookeis,这样我们就可以保持会话,将cookies等值自动传到下一个接口:
importrequests# 登录接口log_url="http://shopxo.hctestedu.com/index.php?s=/index/user/login.html"# 登录参灵敏data= {"accounts": "longge", "pwd": "888888"} # 头部信息head= {"X-Requested-With": "XMLHttpRequest"} # 实例化session对像session=requests.session() login_response=session.post(log_url, data=data, headers=head) # 订单接口order_url="http://shopxo.hctestedu.com/index.php?s=/index/cart/index.html"# 不用手动传入cookies值,因为session自动带上了order_response=session.get(order_url) print(order_response.text) # 打印cookiesprint(session.cookies)