职教云网课进度分析(秒网课)+批量获取CellID的python代码
本帖最后由 hhxk 于 2020-4-29 14:26 编辑先来张效果图:
https://pan.lanol.cn/zb_users/upload/2020/04/202004271587989025773154.png
当打开课件之后,发现右侧或不断发送一个包StuProcessCellLog的包,初步估计这就是不断向服务器发送我们目前的观看情况的包
https://pan.lanol.cn/zb_users/upload/2020/04/202004271587985888764688.png
https://pan.lanol.cn/zb_users/upload/2020/04/202004271587985998255045.png
点开之后翻到最下面,可以看到Form Data,经过自己之前补签的分析,可以猜到下面对应的值的信息,以及刷网课的思路
https://pan.lanol.cn/zb_users/upload/2020/04/202004271587986669460312.png
CourseOpenID:这个课程ID可以直接在网址栏查看
OpenClassID:这个课程班级ID一样的可以直接在网址栏看上面这两个值在同一个课程都是不变的CellID:这个就是下一步分析怎么来的了token:后来发现这个和Cookie里面的token是一样的,所以也可以不变下面是分析CellID的获取过程:1,首先是获取整个课件的大列表,也就是下图这一块
https://pan.lanol.cn/zb_users/upload/2020/04/202004271587986329897120.png
打开之后按F12,打开工具,然后刷新网页可以看到,多了三个东西出来getProcessList,getStuStudyClassList,getTopicByModuleId
https://pan.lanol.cn/zb_users/upload/2020/04/202004271587986375152950.png
一个个来看吧,从第一个开始getProcessList:他提交了两条数据,一个是课程id一个是课程班级id返回来一个list,全部展开之后就是我们的课件列表了
https://pan.lanol.cn/zb_users/upload/2020/04/202004271587986624507267.png
返回来第一级目录,和他的ID
https://pan.lanol.cn/zb_users/upload/2020/04/202004271587986763701338.png
然后是第二个getStuStudyClassList:这个是获取你账户下有哪些课程,在这里可以不用管第三个是getTopicByModuleId可以看到这个是二级目录的id,
然后uptopicid这个应该是上传者的id(网易翻译猜的,在这里没啥用,不过修改作业时间那里需要这个id)
https://pan.lanol.cn/zb_users/upload/2020/04/202004271587987089770321.png
到这里,目前的三个包已经分析完了,但是还是没有得到刷进度要的CellID,这三个包只翻出来二级目录,还差最后课件的ID就行了,
那是因为我们还没有展开课件,所以没有加载,然后我们现在来点开二级目录查看一下
https://pan.lanol.cn/zb_users/upload/2020/04/202004271587987363715463.png
查看一下Form Data:
https://pan.lanol.cn/zb_users/upload/2020/04/202004271587988585501226.png
一个三个值,第一个courseOpenID:说过了的,第二个OpenClassID:说过的,第三个topicid:现在说topicid:fzpq初步估计就是就是之前传递过的值,
经对比可以发现这个id等于我们获取到的二级目录ID。到这里就已经得到了最开始我们所需要的CellID了
https://pan.lanol.cn/zb_users/upload/2020/04/202004271587988788100424.png
回过神看这个文件列表发现,职教云好实诚呀。。
https://pan.lanol.cn/zb_users/upload/2020/04/202004271587988815581348.png
第一个getProcessList:获取列表
第二个getStuStudyClassList:获取学生学习班级列表
第三个TopicidByMouduleid:通过Moduleid获取Topicid
第四个getCellByTopicId:通过Topicid获取CellID总上就可以快乐的为所欲为了
最后附上批量获取课程CellID的python代码import random
import time
import requests
def get_all():
url = 'https://zjyapp.icve.com.cn/newmobileapi/assistTeacher/getModuleListByClassId'
data = {
'courseOpenId': 'courseOpenId',
'openClassId': 'courseOpenId',
'stuId': 'stuId',
}
html = requests.post(url=url, data=data).json()
data = html['moduleList']
moduleIds = []
for i in data:
print(i['moduleName'] + '已加载')
moduleIds.append(i['moduleId'])
return moduleIds
def get_list(moduleId):
url = 'https://zjy2.icve.com.cn/newmobileapi/assistTeacher/getTopicListByModuleId'
moduleIds = []
for i in moduleId:
data = {
'openClassId': 'openClassId',
'courseOpenId': 'courseOpenId',
'moduleId': f'{i}'
}
html = requests.post(url=url, data=data).json()
data = html['topicList']
for j in data:
moduleIds.append(j['topicId'])
return moduleIds
def get_cell(topicIds):
url = 'https://zjy2.icve.com.cn/newmobileapi/assistTeacher/getCellListByTopicId'
cellids = []
for k in topicIds:
data = {
'openClassId': 'openClassId',
'courseOpenId': 'courseOpenId',
'topicId': k,
'stuId': 'stuId'
}
html = requests.post(url=url, data=data).json()
data = html['cellList']
for i in data:
if i['categoryName'] == '子节点':
for j in i['cellChildNodeList']:
cellids.append(j['cellId'])
else:
cellids.append(i['cellId'])
return cellids
--------------------------------------------------------------
补签操作我就不做教程了,代码我已经放到GitHub了:https://github.com/vastsa/ZhiJiaoYunQianDao
给个小star好不好嘿嘿, 学习一下 tt4155 发表于 2020-4-28 11:41
如果全部是get的呢没有post 打小报告全是get
一般get就更加的老实了,要传递的参数全部在那个request url里面,你可以这样拆分一下
从?开始就是第一个参数然后后面有一个=号,就是这个参数的值
每次&后面就会另跟一个参数 真心谢谢楼主精彩的分享!!!! 感谢楼主分享,可惜小白不会用 感谢分享 云教育都可以使用吗,正愁找不到刷时间的呢,谢谢了 刘留留 发表于 2020-4-28 11:09
云教育都可以使用吗,正愁找不到刷时间的呢,谢谢了
这个我就不清楚了,这个是职教云的,但是感觉原理应该都一样吧 谢谢楼主 看不了图 还是小白 先学习下 sensen 发表于 2020-4-28 11:27
看不了图
刷新一下,现在应该可以了