python的requests模块实现登陆示例

51cto用python的requests模块实现登陆示例代码如下:

-- coding:utf-8 --
import requests
import re

client = requests.session()
agent = "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/62.0.3202.94 Safari/537.36"
header = {
"User-Agent": agent
}

URL = "http://home.51cto.com/index"
def get_xsrf():
#获取xsrf值
response = client.get(URL, headers=header)
match_obj = re.search('.name="csrf-token" content="(.?)"', response.text)
if match_obj:
return match_obj.group(1)
else:
return ""

def _51cto_login(account, password):
#51cto登录
post_url = URL
post_data = {
"_csrf": get_xsrf(),
"LoginForm[username]": account,
"LoginForm[password]": password,
#虽然抓包分析时post有以下2个参数,但是实际登陆时以下两个参数可有可无
#"LoginForm[rememberMe]": 0,
#"login-button": "登 录"
}
response = client.post(post_url, data=post_data, headers=header)
#只有上面认证通过后,请求以下页面才可以看到登陆后的结果
response = client.get(URL)
#print response.content
print response.text

_51cto_login("填入真实的用户名", "填入真实的密码")

本文转自 老鹰a  51CTO博客,原文链接:http://blog.51cto.com/laoyinga/2046765


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值