Skip to content

b71db892/AutoCheckInUESTC

Repository files navigation

UESTC电子科技大学(研究生)每日健康打卡

  • 模拟手动登录、过滑动验证码等步骤。

严正声明

各组织机构的健康打卡制度是国家疫情防控的重要一环,违反疫情防控有关规定需付刑事责任.此项目仅供学习交流,不可用于违法违规用途.使用本项目造成的任何后果使用者自行承担.

快速使用示例

  • chrome+chromedriver软件包下载地址:https://www.mediafire.com/folder/ty2a7wlx1kl3h/AutoCheckInUESTC
  • Windows x64 or Ubuntu x64
    # 1. 下载 AutoCheckInUESTC所有代码
    
    # 2.1 For Ubuntu: 下载chrome97_ubuntu64.tar.gz并解压到对应目录
    tar -zxvf chrome97_ubuntu64.tar.gz -C AutoCheckInUESTC/chrome
    
    # 2.2 For Windows: 下载chrome97_win10_64.zip并解压到目录 AutoCheckInUESTC/chrome/
    
    # 3. python环境安装示例:
    # 使用conda创建名为`auto`的虚拟环境.(需安装Anaconda或Miniconda)
    conda create -n auto python=3.7 numpy opencv -y
    # 激活并进入该环境
    conda activate auto
    # 使用pip安装指定版本的依赖
    pip install undetected_chromedriver==3.0.3
    pip install selenium==4.0.0b4
    
    # 4. 配置打卡账户
    # 把账号密码写进`config.py`的`user_list`里,支持多用户一起签到
    # 例如
    user_list = [
            User('1234567890', 'Mima12345?789', ''),
        ]
    
    # 5. 运行
    cd AutoCheckInUESTC
    conda activate auto
    python main.py
    
    

软件依赖

需要安装 chrome 浏览器, chromedriver. 以下方式任选其一 :

  1. 直接下载打包好的chrome+chromedriver软件包[win10_x64 or ubuntu_x64], 下载地址: https://www.mediafire.com/folder/ty2a7wlx1kl3h/AutoCheckInUESTC , 解压到项目内的chrome文件夹下. linux 解压可以用这条命令tar -zxvf chrome97_ubuntu64.tar.gz -C AutoCheckInUESTC/chrome/
  2. 或者, 如果你已经安装了最新的chrome, undetected_chromedriver程序将自动下载并缓存最新的chromedriver. 当你升级chrome时要手动清除项目目录下的 chromedriver.exe or chromedriver 缓存.
  3. 或者, 你希望使用特定版本的chrome和chromedriver,可以在这里下载:https://chromedriver.chromium.org/downloads , 下载后放到chrome文件夹下. 保证该目录下有chromedriver.exechrome.exe(linux 下为chromedriverchrome)这两个可执行文件.

环境依赖

  • windows 10 64位请安装以下环境

    # 手动配置请安装以下python包:
    python >= 3.7       # 版本无严格要求, 但是尽量使用3.7版本避免包依赖问题
    numpy               # 版本无严格要求
    selenium==4.0.0b4   # 请使用 pip 安装
    opencv              # 版本无严格要求,这个包在pip安装的时候名字叫`opencv-python`,conda 安装的时候叫做`opencv` or `py-opencv`
    undetected_chromedriver == 3.0.3 # 这个包用pip安装,win10下版本3.0.3通过测试,3.1.3未通过测试
    
    # 如需开发调试,还要安装以下包:
    matplotlib          # 版本无严格要求

配置打卡账户

  • 把账号密码写进config.pyuser_list里,支持多用户一起签到

    # 把账号密码写进`config.py`的`user_list`里,支持多用户一起签到
    # 例如
    user_list = [
           User('1234567890', 'Mima12345?789', ''),
           User('0987654321', 'ababxyxyawsd9', ''),
       ]
  • 推荐结合windows/Linux计划任务功能,实现每天运行一次自动打卡.

开启微信通知

套娃是吧???

这个比较麻烦,而且不是很必要. 运行这个程序初心就是最小化被通知消息打扰的可能性,避免错过其他重要信息.现在通知群管你打不打卡一天都是七八条打卡通知.(我...) 累了累了(大家都不容易). 如果您还需要该打卡程序通过微信告知你程序运行结果的话,请按照以下步骤配置.

  • 注册微信公众测试号.

打开以下网址:https://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=sandbox/login ,点击登录后用微信扫描登陆.然后就能看到appIDappsecret,先不着急复制.

  • 关注

用自己的微信扫码(刚刚那个页面下面有测试号二维码)关注这个测试号,刷新一下网页就会发现用户列表里多了一个用户的昵称和微信号等信息,不着急复制,待会会用.

  • 新增模板消息

模板消息接口板块有个绿色的新增测试模板按钮,新增两个模板,标题和内容如下:

# 模板1
模板标题:打卡成功
模板内容:时间:{{datetime.DATA}} 用户:{{user.DATA}} {{text.DATA}} 

# 模板2
模板标题:打卡失败
模板内容:时间:{{datetime.DATA}} 用户:{{user.DATA}} {{text.DATA}} 

填好后每个模板会有一个唯一ID,就是页面上模板ID(用于接口调用)这一列的内容,待会会用.

  • 配置编辑wechat.py
wechat_options = {
    "appID": "zdfgbnstu86e75jsrte4s56uj",  # 页面上的 appID
    "appsecret": "4w5u6eo76kjahestgjassrxfnzdrhtrjsm",  # 页面上的 appsecret
    "ok_tpl_id": "aewhrzdnjrkystduhtgrctymjtjhgkxmf",  # 这个是标题为'打卡成功'模板的模板id,请替换成自己的
    "failed_tpl_id": "awersfnjndfznrysjrgeazdrsgerjterhjnzrtgj",  # 这个是标题为'打卡失败'模板的模板id,请替换成自己的
}
  • 务必别忘了配置微信号(open_id)
# 例如
user_list = [
    # 各式:User(user_name, passwd, wechat_openid)
    # 第三项wechat_openid是微信测试号页面上[用户列表]栏里[微信号]的值,是关注测试微信号用户的open_id
    # 不启用WeChat通知功能的话该项留空,填None 或者 '' 都可
    # 例如: User('1234567890', '123456Abc@#$', ''),
        User('1234567890', 'Mima12345?789', 'awegretjsukjyhaegrtsyuykeragvf'),
    ]
  • 测试一下能不能收到消息
# wechat.py 结尾的 __mian__ 代码部分填上要接受消息的微信号(微信测试号页面用户列表里的微信号wechat_openid)
wechat_user_id = 'abcabcabcabcabcabcabcabcabc'
# 运行
python wechat.py
# 然后关注的测试公众号应该会给你发两条模板消息.秒发,几乎没有延迟.

About

UESTC电子科技大学每日健康打卡报平安(研究生),模拟手动登录、过滑动验证码等步骤。

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors

Languages