脚本专栏 
首页 > 脚本专栏 > 浏览文章

Python 实现网课实时监控自动签到、打卡功能

(编辑:jimmy 日期: 2024/11/19 浏览:3 次 )

响应国家停课不停学的号召,学生们都开始了网上授课,但由于课程繁多,消息繁杂,经常错过课堂签到,针对这一难题,博客主作为Python爱好者,完全使用Python语言写了本篇博客,希望能够帮助小伙伴们完成上课签到问题(注:只是帮你签到,而不是叫你代签,我的出发点是帮助记性不是很好的同学签到,防止漏签被老师点名),所以希望大家能理解博主的苦心。

Python 实现网课实时监控自动签到、打卡功能

话不多说,献上效果图两张

Python 实现网课实时监控自动签到、打卡功能
Python 实现网课实时监控自动签到、打卡功能

进入正式教程

①Python环境
Python3.6及以上版本,需要配备的库requests,json,time
代码运行软件:Pycharm

**

②手动登录

手动登录地址:http://mooc1-api.chaoxing.com/mycourse/backclazzdata"text-align: center">Python 实现网课实时监控自动签到、打卡功能

③Cookie获取
在签到过程中最基本的就是用户的Cookie,相当于用户的身份证,在最初写的Python版本中,我直接将我自己的Cookie作为参数保存在代码中,但是经过测试发现由于每个用户的Cookie不同所以后出现报错,所以辛苦小伙伴们手动获取个人Cookie,放入代码中,详细Cookie获取流程如下图所示
注:登录完成后右键审核元素,可以来到此页面

Python 实现网课实时监控自动签到、打卡功能

将自己的Cookie值copy放入如下代码

#填入Cookie
headers={
 "Cookie": "",
 "User-Agent": "Mozilla/5.0 (iPad; CPU OS 13_3_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148 ChaoXingStudy/ChaoXingStudy_3_4.3.2_ios_phone_201911291130_27 (@Kalimdor)_11391565702936108810"
}

Cookie值放置好后,剩余代码不需要做修改,可直接使用,大家如果对代码有疑问或者好的建议可以随时评论区dd我
由于最近学习任务比较重,剩余的代码也不多做讲解,直接奉上,爱好编程的小伙伴可以自己思考一下流程
完整代码奉上(注:Cookie值自补)

#!/usr/bin/python3
# -*- coding: utf-8 -*-
# @Time : 2020/3/5 13:19
# @Author : HaoXuan
# @Email : 879316712@qq.com
# @File : 超星学习通实时签到监控.py
# @Software: PyCharm
import requests
import json
import time

#填入Cookie
headers={
 "Cookie": "",
 "User-Agent": "Mozilla/5.0 (iPad; CPU OS 13_3_1 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148 ChaoXingStudy/ChaoXingStudy_3_4.3.2_ios_phone_201911291130_27 (@Kalimdor)_11391565702936108810"
}
#填入uid
uid=""
coursedata=[]
activeList=[]
course_index=0
speed=10
status=0
status2=0
activates=[]
def backclazzdata():
 global coursedata
 url="http://mooc1-api.chaoxing.com/mycourse/backclazzdata"
 res=requests.get(url,headers=headers)
 cdata=json.loads(res.text)
 if(cdata['result']!=1):
  print("请补充Cookie否则课程列表获取失败")
  return 0
 for item in cdata['channelList']:
  if("course" not in item['content']):
   continue
  pushdata={}
  pushdata['courseid']=item['content']['course']['data'][0]['id']
  pushdata['name']=item['content']['course']['data'][0]['name']
  pushdata['imageurl']=item['content']['course']['data'][0]['imageurl']
  pushdata['classid']=item['content']['id']
  coursedata.append(pushdata)
 print("获取成功") 
 #print(coursedata) 
 printdata()

def printdata():
 global course_index,speed
 index=1
 for item in coursedata:
  print(str(index)+".课程名称:"+item['name'])
  index+=1
 course_index=int(input("请输入监控课程监控课程序号:"))-1
 print("监控课程设定完成")
 speed=int(input("请输入监控频率:")) #频率是监控的速度,一格10秒,适中选择就好
 print("监控频率设置完毕")
 res=input("输入666启动监控:")
 if(res=="start"):
  startsign()
 else:
  printdata 

def taskactivelist(courseId,classId):
 global activeList
 url="https://mobilelearn.chaoxing.com/ppt/activeAPI/taskactivelist"+str(courseId)+"&classId="+str(classId)+"&uid="+uid
 res=requests.get(url,headers=headers)
 data=json.loads(res.text)
 activeList=data['activeList']
 #print(activeList)
 for item in activeList:
  if("nameTwo" not in item):
   continue
  if(item['activeType']==2 and item['status']==1):
   signurl=item['url']
   aid = getvar(signurl)
   if(aid not in activates):
    print("【签到】查询到待签到活动 活动名称:%s 活动状态:%s 活动时间:%s aid:%s"%(item['nameOne'],item['nameTwo'],item['nameFour'],aid))
    sign(aid,uid) 

def getvar(url):
 var1 = url.split("&")
 for var in var1:
  var2 = var.split("=")
  if(var2[0]=="activePrimaryId"):
   return var2[1]
 return "ccc" 

 

def sign(aid,uid):
 global status,activates
 url="https://mobilelearn.chaoxing.com/pptSign/stuSignajax"+aid+"&uid="+uid+"&clientip=&latitude=-1&longitude=-1&appType=15&fid=0"
 res=requests.get(url,headers=headers)
 if(res.text=="success"):
  print("用户:"+uid+" 签到成功!")
  activates.append(aid)
  status=2
 else:
  print("签到失败") 
  activates.append(aid) 

def startsign():
 global status,status2
 status=1
 status2=1
 ind=1
 print("监控启动 监控课程为:%s 监控频率为:%s"%(coursedata[course_index]['name'],str(speed)))
 while(status!=0 and status2!=0):
  ind+=1
  taskactivelist(coursedata[course_index]['courseid'],coursedata[course_index]['classid'])
  time.sleep(speed)
  if(status==1):
   print(str(ind)+" [签到]监控运行中,未查询到签到活动")
  elif(status==2):
   print(str(ind)+" [新签到]监控运行中,未查询到签到活动")   
 print("任务结束")
 printdata()

backclazzdata()

原理很简单,有兴趣大家也可以自己动手实现一下,如果大家想学习,可以细读一次Python的代码,有兴趣的可以私信我,我将用到的API和python代码打包发给你(Python代码没有加登陆模块,有能力的的可以自己实现一下)
谢谢大家!

Python 实现网课实时监控自动签到、打卡功能

最后,说一下这个自动实时监控签到一个软件只能监控一个课程,但是能多开实现多门课程监控
然后,本代码可以满足普通签到,收拾签到,位置签到(位置信息空白),不支持照片签到(希望又大牛可以解决这个问题)由于程序不完善,可能会提示失败但是如果点开学习通查询,是显示已经完成签到。

Python 实现网课实时监控自动签到、打卡功能

上一篇:Python线程协作threading.Condition实现过程解析
下一篇:Python基于read(size)方法读取超大文件
一句话新闻
一文看懂荣耀MagicBook Pro 16
荣耀猎人回归!七大亮点看懂不只是轻薄本,更是游戏本的MagicBook Pro 16.
人们对于笔记本电脑有一个固有印象:要么轻薄但性能一般,要么性能强劲但笨重臃肿。然而,今年荣耀新推出的MagicBook Pro 16刷新了人们的认知——发布会上,荣耀宣布猎人游戏本正式回归,称其继承了荣耀 HUNTER 基因,并自信地为其打出“轻薄本,更是游戏本”的口号。
众所周知,寻求轻薄本的用户普遍更看重便携性、外观造型、静谧性和打字办公等用机体验,而寻求游戏本的用户则普遍更看重硬件配置、性能释放等硬核指标。把两个看似难以相干的产品融合到一起,我们不禁对它产生了强烈的好奇:作为代表荣耀猎人游戏本的跨界新物种,它究竟做了哪些平衡以兼顾不同人群的各类需求呢?
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 SiteMap