Skip to content

uestcer/UESTC_Helper

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

29 Commits
 
 
 
 
 
 

Repository files navigation

原始请求

大一上

2014000201010:ignoreHead=1&setting.kind=std&startWeek=1&project.id=1&semester.id=43&ids=134775

大一下

2014000201010:ignoreHead=1&setting.kind=std&startWeek=1&project.id=1&semester.id=63&ids=134775

大二上

2014000201010:ignoreHead=1&setting.kind=std&startWeek=1&semester.id=84&ids=134775 2014000201016:ignoreHead=1&setting.kind=std&startWeek=1&semester.id=84&ids=134781

大二下

2014000201010:ignoreHead=1&setting.kind=std&startWeek=1&project.id=1&semester.id=103&ids=134775

eams.uestc.edu.cn/eams/dataQuery.action

2014000201010: 2014000201016:tagId=semesterBar9459456391Semester&dataType=semesterCalendar&value=84&empty=false

response:

{
    yearDom: "<tr><td class='calendar-bar-td-blankBorder' index='0'>2008-2009</td><td class='calendar-bar-td-blankBorder' index='1'>2009-2010</td><td class='calendar-bar-td-blankBorder' index='2'>2010-2011</td></tr><tr><td class='calendar-bar-td-blankBorder' index='3'>2011-2012</td><td class='calendar-bar-td-blankBorder' index='4'>2012-2013</td><td class='calendar-bar-td-blankBorder' index='5'>2013-2014</td></tr><tr><td class='calendar-bar-td-blankBorder' index='6'>2014-2015</td><td class='calendar-bar-td-blankBorder' index='7'>2015-2016</td><td class='calendar-bar-td-blankBorder' index='8'>2016-2017</td></tr>",
    termDom: "<tr><td class='calendar-bar-td-blankBorder' val='84'><span>1</span>学期</td></tr><tr><td class='calendar-bar-td-blankBorder' val='103'><span>2</span>学期</td></tr>",
    semesters: {
        y0: [
            {
                id: 21,
                schoolYear: "2008-2009",
                name: "1"
            },
            {
                id: 22,
                schoolYear: "2008-2009",
                name: "2"
            }
        ],
        y1: [
            {
                id: 19,
                schoolYear: "2009-2010",
                name: "1"
            },
            {
                id: 20,
                schoolYear: "2009-2010",
                name: "2"
            }
        ],
        y2: [
            {
                id: 17,
                schoolYear: "2010-2011",
                name: "1"
            },
            {
                id: 18,
                schoolYear: "2010-2011",
                name: "2"
            }
        ],
        y3: [
            {
                id: 15,
                schoolYear: "2011-2012",
                name: "1"
            },
            {
                id: 16,
                schoolYear: "2011-2012",
                name: "2"
            }
        ],
        y4: [
            {
                id: 13,
                schoolYear: "2012-2013",
                name: "1"
            },
            {
                id: 14,
                schoolYear: "2012-2013",
                name: "2"
            }
        ],
        y5: [
            {
                id: 1,
                schoolYear: "2013-2014",
                name: "1"
            },
            {
                id: 2,
                schoolYear: "2013-2014",
                name: "2"
            }
        ],
        y6: [
            {
                id: 43,
                schoolYear: "2014-2015",
                name: "1"
            },
            {
                id: 63,
                schoolYear: "2014-2015",
                name: "2"
            }
        ],
        y7: [
            {
                id: 84,
                schoolYear: "2015-2016",
                name: "1"
            },
            {
                id: 103,
                schoolYear: "2015-2016",
                name: "2"
            }
        ],
        y8: [
            {
                id: 123,
                schoolYear: "2016-2017",
                name: "1"
            }
        ]
    },
    yearIndex: "7",
    termIndex: "0",
    semesterId: "84"
}

可以获取到:semester.id

可以获取到dataQuery所需的参数:tagId,value以及ids(第99行)

把上面得到的参数都post到这个地址,就能获取课程表的原始数据了 然后用正则表达式匹配出所需数据,之后就是解析并格式化数据了。

终于发现了课程表的奥秘所在! 如下所示的代码,揭示了这门课的所有信息。

activity = new TaskActivity("10024", "牟柳", "6794(B0000820.01)", "英语会议交流与汇报(B0000820.01)", "442", "品学楼C-204", "00000000001111111100000000000000000000000000000000000");
index = 3 * unitCount + 2;
table0.activities[index][table0.activities[index].length] = activity;
index = 3 * unitCount + 3;

里面TaskActivity接收的参数很明了,其中一大堆0和1那个其实是课的分布图,对应了一年的53周。 然后下面的几行代码则是这门课上课的时间,unitCount其实就是一天的课数,默认值为12,然后index=m*unitCount+n里面,m代表周几,n代表当天的第几节课,都是从0开始计数的。

这样,课程表就很容易解析出来了。

获取考试安排

ajax({
    url: 'http://eams.uestc.edu.cn/eams/stdExamTable!examTable.action?semester.id=103&examType.id=1&_=1475140136119',
    method: 'GET'
});

参数说明:

semester.id: 学期代号
examType.id: 考试类型(1,2,3,4)
_: 时间戳

About

“干掉丑陋的教务网站”计划

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 65.9%
  • HTML 17.4%
  • CSS 16.7%