Skip to main content

Login to *.ruc.edu.cn, get cookies.

Project description

ruclogin

PyPI Downloads GitHub Repo stars

ruclogin 可以帮助你快速地获取和检查 v.ruc.edu.cn (and jw.ruc.edu.cn) 的 cookies,使用 selenium 和 requests。可能的用途包括爬虫,抢课等。

Simple Example

import ruclogin
ruclogin.update_username_and_password("2021201212", "ABC12345")
cookies = ruclogin.get_cookies(domain="v.ruc.edu.cn") # you can also use domain="jw.ruc.edu.cn"
cookies
# {'tiup_uid': '6112329b90f4d162e19b83c9', 'session': '7a0b09dc5f5c4587aae0511247ae276d.834554d714de4c19b6ca1ec111ab3514', 'access_token': '1Jf8zOE7S5SYHYS3x5nNHA', 'is_simple': '1'}

Get Started

0. Install ruclogin

pip install ruclogin

1. Install Chrome or Edge, and download the corresponding driver

  • Chrome,推荐,作者版本更新时只保证对 Chrome 的支持
  • Edge

接着你需要查看你的浏览器版本并下载尽量最对应的最新的浏览器驱动

我们假设你下载的驱动文件放在 D:/Other/driver/chromedriver.exe

2. Set your username, password and preferred browser in terminal

ruclogin --username 2021201212 --password ABC12345 --browser Chrome --driver "D:/Other/driver/chromedriver.exe"

或者使用交互式命令行

ruclogin

像这样,请注意,密码的输入不带回显(即不显示你输入的内容),你只需要直接输入,然后回车。

(base) PS D:\Code\ruclogin> ruclogin     
username, type enter to skip: 2021201212
password, type enter to skip: 
browser(Chrome/Edge), type enter to skip:
driver_path, type enter to skip:

Config D:\Program\anaconda3\Lib\site-packages\ruclogin\config.ini updated:
        Username: 2021201212
        Password: ******
        Browser: Chrome
        driver_path: D:/Other/driver/chromedriver.exe


Test login? (Y/n):
你好, 信息学院 xxx from v.ruc.edu.cn
你好,xxx 图灵实验班(信息学拔尖人才实验班),你一共修了123学分,48门课,平均绩点3.9,专业排名第2名 from jw.ruc.edu.cn
driver init time: 4.749s
v.ruc.edu.cn get cookies time: 1.587s, check cookies time: 0.348s
jw.ruc.edu.cn get cookies time: 1.925s, check cookies time: 0.395s

3. Get your cookies

from ruclogin import *

# you can also update your username and password like this:
# update_username_and_password("2021201212", "ABC12345")      # will save in disk
# print(get_username_and_password())                          # ("2021201212", "ABC12345")

cookies = get_cookies(cache=False, domain="v")          # regain cookies, login in using selenium, save in disk
print(cookies)                                          # {'tiup_uid': '6112329b90f4d162e19b83c9', 'session': '7a0b09dc5f5c4587aae0511247ae276d.834554d714de4c19b6ca1ec111ab3514', 'access_token': '1Jf8zOE7S5SYHYS3x5nNHA', 'is_simple': '1'}
success = check_cookies(cookies, domain="v")            # check cookies using requests
if success:
    print(success)                                      # 你好, xx学院 xxx from v.ruc.edu.cn                      
cookies = get_cookies()                                 # cache=True, it will use the cookies obtained last time, check it first, if it fails, regain it

无论用什么方式设置用户名和密码,你只需要设置一次。

Remind

拥有 cookies 相当于拥有微人大的完全访问权限,请不要和任何人分享。

执行 ruclogin --reset 可以将所有信息初始化(包括配置文件内保存的用户名密码,以及缓存的 cookies)。

Q&A

Q: 控制台输出 DevTools listening on ws://..... ?

A: 这个输出关不掉,似乎是最新版 ChromeDriver 的一个问题,目前没有解决方案,不影响用,但是会有烦人的提示。

Q: 我遇到了其他报错。

A: 运行 ruclogin --debug 可以显示浏览器的操作过程,这可能有助于你发现问题。如果你是开发者,欢迎提交 pr 修复。

兼容性测试

如果遇到问题,你可以尝试参考 Github Actions 一通过测试的环境。

打开 Actions,选择对应系统的 Workflow,比如 Linux Test,进入最近的一次 job:

  • 展开 Set up job,展开 Operating System,可以看到使用的系统镜像,比如 Ubuntu 20.04.5 LTS
  • 展开 Set up Chrome,可以看到使用的 Chrome 版本,比如 Successfully setup chromium 130.0.6723.91Successfully setup ChromeDriver 130.0.6723.91

Update

0.3.2

Quit driver in destructor of RUC_LOGIN, #8.

更新到更现代的 pyproject.toml。

修改了 reset 的逻辑为删除 cache。

优化了 debug 体验,你可以在 test login 失败时选择抛出异常。

为命令行脚本添加了 --no_interactive--silent 参数,可用于 CI/CD。

为项目添加了 GitHub Actions,目前只支持 Chrome 测试。

0.3.1

新增依赖 blinker==1.7.0,见 #7。@JasonHuang0812

因为作者观察到的 “[WinError 193] %1 不是有效的 Win32 应用程序。”,怀疑是 webdriver_manager 存在问题,现在总是要求手动指定 driver_path。 如果你需要原来的自动下载功能,可以删除 ruclogin.py 中 124 和 139 行的 raise ConnectionError

0.3.0

修复了使用 Edge 浏览器时, Cookies 获取不正常的 BUG。

大幅度增强了访问时的鲁棒性。

0.2.12

增加了 --debug 参数,可以显示浏览器的操作过程。

0.2.11

适配最新教务网站。

0.2.10

修改了密码的输入方式,现在不回显(即非明文输入)。

增加了 --reset 参数用于清空隐私数据。

因为精力所限,删除对 Chromium 的支持。

0.2.9

更干净的包卸载,支持临时指定 username 和 password(以方便多用户)。

0.2.8

随着 ddddocr 的更新,Pillow 的旧版本要求现在被删去。

0.2.7

修复部分 bug,通过了服务器运行。

0.2.6

细化了报错提示,更容易检查。

再次优化了 check_cookies 的输出以适应学期变化。

ruclogin test 现在还会输出耗时。

集成了 semester2codecode2semester 两个函数,用于学期和学期代码之间转换。

0.2.5

支持了手动管理浏览器驱动。

删去了 ruclogin test 时请求用户输入前的额外换行。

0.2.3

修改了 check_cookies 的输出,现在会输出所用测试请求的结果例如:“你这学期的课有:并行与分布式计算 计算机系统实现Ⅰ 后人类时代的全球影像 机器学习与计算智能Ⅰ 数据库系统概论荣誉课程 迁移学习 科学技术哲学”,失败返回 None。

0.2.1

提高 check_cookies 的鲁棒性。

0.2

新增 jw.ruc.edu.cn cookies 支持。

from ruclogin import *
cookies = get_cookies(domain="jw") # or get_cookies(domain="jw.ruc.edu.cn")
check_cookies(cookies, domain="jw")

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ruclogin-0.3.2.tar.gz (17.1 kB view details)

Uploaded Source

Built Distribution

ruclogin-0.3.2-py3-none-any.whl (13.7 kB view details)

Uploaded Python 3

File details

Details for the file ruclogin-0.3.2.tar.gz.

File metadata

  • Download URL: ruclogin-0.3.2.tar.gz
  • Upload date:
  • Size: 17.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.4

File hashes

Hashes for ruclogin-0.3.2.tar.gz
Algorithm Hash digest
SHA256 514a580709e025d5dd14874c7d3b017a5e054fd8c016ca864d3e275b7abae3fb
MD5 032f8c81dad88debb8898dec612dbba8
BLAKE2b-256 93239076154cce550ef8aa0747c8ebbdd8bf2e4d6a796d55a1651d8e6ad7a90a

See more details on using hashes here.

File details

Details for the file ruclogin-0.3.2-py3-none-any.whl.

File metadata

  • Download URL: ruclogin-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 13.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.4

File hashes

Hashes for ruclogin-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 52c387c1dc6e3abc4621b72f17760122ce92d31e6bd3002522c0b4cc68024c56
MD5 117dd6a29fd51433f7c67c3f7a2196ee
BLAKE2b-256 2c757a0f02651dd0a7ff4f32c5b1c9f3a206ed8aaffbab3c0302a0ec8d91cbac

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page