python爬虫之模拟登陆(CSDN篇)

请求大神帮助

最近想搞一下爬虫的模拟登陆,就想直接拿CSDN练手了,一开始还想着一篇文章写完,写到一半发现,大意了,CSDN有加密,得慢慢啃了,啃着啃着谁知道又发现问题了。

打开F12,查看网页源码

在这里插入图片描述

点击F5刷新,并勾选preserve log

在这里插入图片描述
勾选preserve log 是为了查看登陆成功后,也就是页面刷新前的网页文件,我们需要搞清楚它提交了什么样的参数。

进行一次账号登陆

这一次账号登陆就是为了搞清楚发送给服务器的参数,在这里建议使用错误的账号和密码,进行一次失败登陆,这样会方便的找到响应的文件
在这里插入图片描述
这个链接使用的是post方式,是向服务器发送数据
在这里插入图片描述
这里就是发送的数据的详细情况,可以直观地看到我们填写的账号密码(当然我这的是错误的),不过还有其他的数据,也就是我之前说的加密啦,还是需要花时间搞一下的。
在这里插入图片描述

import requests
import json

# https://passport.csdn.net/v1/login/wap/login/doLogin
# post的提交链接
url = 'https://passport.csdn.net/v1/register/pc/login/doLogin'
header = {
    'user-agent': 'Mozilla/5.0 (Windows NT 10.0;WOW64) AppleWebKit/537.36 (KHTML, like Gecko) '
                  'Chrome/88.0.4324.104 Mobile Safari/537.36',
    'accept': 'application/json,text/plain,*/*',
    'connection': 'keep-alive',
    'Content-Type': 'application/json;charset=UTF-8',
    'refer': 'https://blog.csdn.net/m0_46104664',
}
data = {
    "pwdOrVerifyCode": 你的密码,
    "userIdentification": 你的账号,
}

session = requests.session()
jsondata = json.dumps(data)
html = session.post(url, headers=header, data=jsondata)


get_url = 'https://blog.csdn.net/m0_46104664'
get_header = {
    'user-agent': 'Mozilla/5.0 (Windows NT 10.0;WOW64) AppleWebKit/537.36 (KHTML, like Gecko) '
                  'Chrome/88.0.4324.104 Mobile Safari/537.36',
}
response = session.get(get_url, headers=get_header)
if response.status_code == 200:
    print(response.text)

但是我发现 ‘https://blog.csdn.net/m0_46104664’ 这个链接直接打开是可以的,也就是下面的代码可以直接运行且会成功

import requests
get_url = 'https://blog.csdn.net/m0_46104664'
get_header = {
    'user-agent': 'Mozilla/5.0 (Windows NT 10.0;WOW64) AppleWebKit/537.36 (KHTML, like Gecko) '
                  'Chrome/88.0.4324.104 Mobile Safari/537.36',
}
response = requsets.get(get_url, headers=get_header)
if response.status_code == 200:
    print(response.text)

而登录那部分的代码直接运行则会显示
在这里插入图片描述
然后我就懵了,我这算是个什么情况???

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值