日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > windows >内容正文

windows

Python实现新版正方教务系统爬虫(二)

發布時間:2024/3/12 windows 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Python实现新版正方教务系统爬虫(二) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

前言

哎對不起 我可能是silly boy 我想在學校里把去年的坑填了 但是發現新版的教務系統代碼沒傳到git上 我現在就成了個對著空ide發呆的憨憨(代碼在家里啦 所以填坑就再過會吧

那就稍微閑聊一下吧 打算填坑前逛了一下csdn上面有關新版正方教務系統的帖子 我去年留下的rsa加密的坑其實都被填掉了 也有用flask框架完善整個項目的
其實挺好的 寫博客就是為了幫助更多的志同道合之人在這條路上進步 告訴你們我是怎么走到這里的 走了多少的坑
為中華崛起而奮斗~~

正文哈

國慶之后終于是想起來要把代碼拷走這回事情,現在基本是填完了啦。
給剛學習爬蟲的小白們做了封裝 希望能夠幫助你們理解

新版的方正教務系統唯一的難點也就是在登陸加密的地方了,這里感謝@qq_14926447 使用了他代碼中的輪子 于是我也能快樂的跑起來啦~

實現的原理貼在上個教程里面了 就直接上干貨吧

github項目鏈接:https://github.com/welsonsxc/NewZFScoreSpider

講解一下

整個流程我封裝成一個類了,方便后續api或者多線程調用
wechat_robot文件夾里是當時做測試公眾號用的 學校方面沒法申請下來經費就逐漸廢棄了 如果你們學校可以的話 不妨研究一下 填填坑

噥 知道你們最喜歡這個了 再次感謝@qq_14926447

# 加密密碼def process_public(self):weibo_rsa_e = 65537message = str(self.password).encode()rsa_n = binascii.b2a_hex(binascii.a2b_base64(self.modules))key = rsa.PublicKey(int(rsa_n, 16), weibo_rsa_e)encropy_pwd = rsa.encrypt(message, key)self.password = binascii.b2a_base64(encropy_pwd)

我知道有人懶得點進github

# -*- coding: utf-8 -*- import binascii import requests from bs4 import BeautifulSoup import re import time import sys import rsaclass Student:sessions = requests.Session()time = int(time.time())def __init__(self, name, password, login_url, key_url, grade_url):self.pub = Noneself.year = Noneself.term = Noneself.token = Noneself.header = Noneself.cookie = Noneself.modules = Noneself.request = Noneself.name = str(name).encode("utf8").decode("utf8")self.password = str(password).encode("utf8").decode("utf8")self.url = login_urlself.KeyUrl = key_urlself.gradeUrl = grade_urlself.get_public_key()self.get_csrf_token()self.process_public()self.login()# 獲取公鑰密碼def get_public_key(self):result = self.sessions.get(self.KeyUrl + str(self.time)).json()self.modules = result["modulus"]# 說實話 這也太那啥了 這居然是沒用的 怪不得去年栽在這里# self.exponent = result["exponent"]# 獲取CsrfTokendef get_csrf_token(self):r = self.sessions.get(self.url + str(self.time))r.encoding = r.apparent_encodingsoup = BeautifulSoup(r.text, 'html.parser')self.token = soup.find('input', attrs={'id': 'csrftoken'}).attrs['value']# 加密密碼def process_public(self):weibo_rsa_e = 65537message = str(self.password).encode()rsa_n = binascii.b2a_hex(binascii.a2b_base64(self.modules))key = rsa.PublicKey(int(rsa_n, 16), weibo_rsa_e)encropy_pwd = rsa.encrypt(message, key)self.password = binascii.b2a_base64(encropy_pwd)def login(self):try:self.header = {'Accept': 'text/html, */*; q=0.01','Accept-Encoding': 'gzip, deflate','Accept-Language': 'zh-CN,zh;q=0.9,en;q=0.8','User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:58.0) Gecko/20100101 Firefox/58.0','Connection': 'keep-alive','Referer': self.url + str(self.time),'Upgrade-Insecure-Requests': '1',}data = {'csrftoken': self.token,'mm': self.password,'mm': self.password,'yhm': self.name}self.request = self.sessions.post(self.url, headers=self.header, data=data)self.cookie = self.request.request.headers['cookie']key_word = r'用戶名或密碼不正確'if re.findall(key_word, self.request.text):print('用戶名或密碼錯誤,請查驗..')sys.exit()else:print("登陸成功")except Exception as e:print(str(e))sys.exit()def post_grade_data(self):try:data = {'_search': 'false','nd': int(time.time()),'queryModel.currentPage': '1','queryModel.showCount': '15','queryModel.sortName': '','queryModel.sortOrder': 'asc','time': '0','xnm': self.year,'xqm': self.term}self.request = self.sessions.post(self.gradeUrl, data=data, headers=self.header).json()except Exception as e:print(str(e))sys.exit()def welcome(self):try:# 姓名name = self.request['items'][0]['xm']# 學歷sch_stu = self.request['items'][0]['xslb']# 學院institute = self.request['items'][0]['jgmc']# 班級stu_class = self.request['items'][0]['bj']print('姓名:{}\t學歷:{}\t\t學院:{}\t班級:{}'.format(name, sch_stu, institute, stu_class))except Exception as e:print(str(e))def print_grades(self):try:plt = '{0:<20}{1:<5}{2:<5}{3:<5}'print(plt.format('課程', '成績', '績點', '教師'))for i in self.request['items']:print(plt.format(i['kcmc'], i['bfzcj'], i['jd'], i['jsxm']))except Exception as e:print("[Error]" + str(e))if __name__ == '__main__':# 輸入學號密碼# stu_name = input('請輸入學號:').strip()stu_name = "你的學號"# stu_password = getpass.getpass('請輸入密碼(密碼不回顯,輸入完回車即可):') .strip()stu_password = "你的密碼"# 教務系統登錄路徑url = "http://你的學校域名或者ip地址/jwglxt/xtgl/login_slogin.html?language=zh_CN&_t="# 請求PublicKey的URLkey_url = "http://你的學校域名或者ip地址/jwglxt/xtgl/login_getPublicKey.html?time="# 獲取成績路徑grade_url = "http://你的學校域名或者ip地址/jwglxt/cjcx/cjcx_cxDgXscj.html?doType=query&gnmkdm=N305005"# 登陸~temp = Student(stu_name, stu_password, url, key_url, grade_url)# 設定學年temp.year = "2018"# 第一學期為3 第二學期為12temp.term = "3"# 選擇成績查詢temp.post_grade_data()# 輸出個人信息temp.welcome()# 輸出成績信息temp.print_grades()

運行結果

感覺沒啥好講的 都是干貨 git大學一定要學會呀 公司里都在用~
如果幫助到你了 煩請star!
最后留個工作郵箱 lilousc@dingtalk.com

總結

以上是生活随笔為你收集整理的Python实现新版正方教务系统爬虫(二)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。