Python中如何实现MOOC扫码登录

 

1、基本原理

  • 访问网站扫码登录页,网站给浏览器返回一个二维码和一个唯一标志KEY
  • 浏览器开启定时轮询服务器,确认KEY对应的扫码结果
  • 用户使用app扫码二维码,app获取KEY并告知服务器已扫码
  • App确认登陆(包含个性化校验过程),服务器更新KEY的校验结果
  • 浏览器轮询结果成功,获得一次性token
  • 带上token请求资源,获得有效cookie,正常访问资源。

 

2、代码实现

我们以MOOC为例

1、访问网站扫码登录页,并下载二维码

session = requests.session()
url = 'https://www.icourse163.org/logonByQRCode/code.do?width=182&height=182'   # 扫码登录url
header = {
  'referer': 'https://www.icourse163.org/',
  'user-agent': ua
}
resp = session.get(url,headers = header).json()		# 拿到相应的json数据
codeUrl = resp['result']['codeUrl']				# 提取二维码url及唯一标志key
pollKey = resp['result']['pollKey']
codejpg = session.get(codeUrl)				# 请求二维码
with open('text.jpg','wb') as f:			# 下载二维码
  f.write(codejpg.content)

2、模拟轮询

利用已得的唯一标志key对服务器发起定时轮询,获得相应数据

通过分析,codeStatus的值为0是表示,等待扫码;codeStatus的值为1是表示,已扫码,等待确认登录;codeStatus的值为2是表示,扫码成功,此时服务器会返回token,这个对我们很有用

checkUrl = f'https://www.icourse163.org/logonByQRCode/poll.do?pollKey={pollKey}'
os.system('start text.jpg')
token = None
for i in range(20):				# 模拟轮询
  checkResp = session.get(checkUrl,headers = header).json()
  if checkResp['result']['codeStatus'] == 2:
      token = checkResp['result']['token']		# 提取token
  else:
      time.sleep(1)			# 每秒一次

3、弹出二维码,扫码登录

os.system('start text.jpg')

4、带上token请求资源

获得有效cookie,正常访问资源。

vaildateUrl = f'https://www.icourse163.org/passport/logingate/mocMobChangeCookie.htm?token={token}&returnUrl=aHR0cHM6Ly93d3cuaWNvdXJzZTE2My5vcmcvaW5kZXguaHRt'	# returnUrl指MOOC网
session.get(vaildateUrl,headers = header)

 

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程宝库

当你提到二维码时,大多数人想到的是仓库管理或产品标签等 "工业 "应用,但这篇文章在很大程度上是关于二维码的个人和社会用途。 有趣的事实二维(QR)码是在1994年发明的,最近几年它的"非接触 "特 ...