基于 Nodejs ,实现的一个签到命令行工具。为了节约性能,只对开始2小时以内的活动签到。特殊情况:同一时间有多个有效签到活动的话,只签最新的。
功能: 普通签到、拍照签到、手势签到、位置签到、签到码签到、二维码签到(10秒变换不影响),多用户凭据储存(多开)。
注意: 本程序仅为交流学习使用,借助学习通的平台,通过本项目加深http请求、网络通信、接口编写、交互设计等方面知识的理解,请勿用作商业以及其他用途。
为确保你的代码最新与仓库保持同步,将在每次签到结束强制拉取代码更新,如需关闭更新,请查看issue2。手动终止检查更新可在每次检查时按下 Ctrl
+C
并确认终止,更多功能正在开发 ...
可在任意运行 NodeJS > v8.5.4 的平台签到,Windows、MacOS、Linux ...
安卓手机上可以用 Termux 来运行NodeJS程序,查看Termux教程 。
苹果手机请查看 高级 部分,通过这种方式来使用,当然这种方式也适用于其他。
将仓库克隆到本地
git clone https://github.com/miaochenxi/chaoxing-sign-cli.git
进入项目文件夹
cd chaoxing-sign-cli
执行以下命令即可
npm start
在运行之前需要做些准备,请找一位挚友,发来拍的二维码的照片(无所谓几秒一变),用微信扫一扫二维码,或用其他工具识别,得到类似下面的结果:
复制其中的 enc
参数,注意不要复制多余内容和空格,例如 1D0A628CK317F44CCC378M5KD92,复制该值,询问时填入。若使用 UI 仓库的项目(查看高级
),则可直接选择图片提交。
根据运行时的提示输入经纬度和详细地址,经纬度可在这里自己获取 百度拾取坐标系统,点击某位置,经纬度将出现在网页右上方,复制该值,询问时填入。详细地址样例:中国河南省郑州市中原区沟赵乡红松路郑州轻工业大学(科学校区),该地址将显示在教师端。
需要事先准备一张用来提交的照片。浏览器访问超星云盘:https://pan-yz.chaoxing.com ,在根目录上传一张你准备的照片,命名为 0.jpg
或 0.png
。若使用 UI 仓库的项目(查看高级
),则可直接选择图片提交。
没有任何需要准备的,直接运行即可。
以上内容介绍了最基本的用法,接下来介绍一些稍高级一些的使用方法。
首先运行 npm install
或者 yarn
,安装依赖。
运行 npm run serve
将启动接口服务,可通过调用 API 来实现以上功能。接下来描述每个接口的参数以及调用方式:
路径 | 请求方式 | 参数 | 内容类型 | 返回内容 |
---|---|---|---|---|
/ | GET | 无 | 无 | 待填 |
/login | POST | phone, password | JSON | 待填 |
/activity | POST | uf, _d, vc3, uid | JSON | 待填 |
/uvtoken | POST | uf, _d, vc3, uid | JSON | 待填 |
/qrcode | POST | uf, _d, vc3, name, aid, uid, fid, enc | JSON | 待填 |
/location | POST | uf, _d, vc3, name, aid, uid, fid, address, lat, lon | JSON | 待填 |
/general | POST | uf, _d, vc3, name, aid, uid, fid | JSON | 待填 |
/photo | POST | uf, _d, vc3, name, aid, uid, fid, objectId | JSON | 待填 |
/upload | POST | uf, _d, vc3, uid, file, ?_token | multipart/form-data | 待填 |
基于 React.js + Material UI 开发前端页面,其中修改了很多 MUI 附带样式,也自己手写了一些,整体设计灵感-->拟态。
访问 这里 查看图形化客户端具体内容。
基本使用步骤:
- 将两个项目依赖都装好
- 在本项目运行
npm run serve
或yarn serve
- 在 UI 项目(与本仓库分离)运行
npm start
或yarn start
- 未作任何修改的情况下,可通过 http://localhost:3000 通过网页使用全部功能
不过我的建议是,构建一下页面,然后部署到服务器自己学习用。
可在 Termux 或服务器上配置并部署
接口服务
和前端页面
, 运行两者,获得最佳体验。
若部署在云函数,请查看 src/functions/photo.js 中的函数 uploadPhoto, 根据注释修改路径。
欢迎对本仓库提交代码,但是在这之前请发起一个Issue描述你想要修改或提供的功能,经过讨论之后再确定是否进行下去,避免辛苦写完代码最终没有得到合并。本项目按照个人意愿进行开发,一些功能以及设计带有个人主观的想法,所以有想法要提交代码的朋友请一定先讨论一下。讨论过后请新建一个分支(以提供的功能命名),并在此分支完成你的代码,提交pull request。请保持代码整洁,不要有一堆散乱的commit对一些没彻底想好的地方改来改去。
非常感谢超星学习通,实践出真知。