Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/do1e/fill_in_captcha

南大统一身份认证自动填充验证码
https://github.com/do1e/fill_in_captcha

nanjing-university nju

Last synced: 13 days ago
JSON representation

南大统一身份认证自动填充验证码

Awesome Lists containing this project

README

        

# 南大统一身份认证自动填充验证码

![效果](img/效果.gif)

识别服务器代码 [server.py](server.py) [@Do1e](https://github.com/Do1e)

Tampermonkey脚本 [send_captcha.js](send_captcha.js) [@Bubbleioa](https://github.com/Bubbleioa)

## 无域名和SSL证书使用(不建议)

注:如果你的服务器已经安装了证书,可在 [server.py L25](server.py#L25) 中修改`certfile`和`keyfile`的值为你的证书路径,或者删除这两个参数使用nginx等反向代理,即可不用配置证书。

### 服务器

1. 下载 [mkcert](https://github.com/FiloSottile/mkcert/releases)
2. 打开终端运行 `./mkcert -install`,安装根证书
3. 运行 `./mkcert xxx.xxx.xxx.xxx`,生成SSL证书,其中`xxx.xxx.xxx.xxx`为你的服务器IP地址。此时得到`xxx.xxx.xxx.xxx.pem`和`xxx.xxx.xxx.xxx-key.pem`两个文件,填入 [server.py L25](server.py#L25) 中的`certfile`和`keyfile`参数。
4. 运行 `./mkcert -CAROOT` 查看根证书路径,找到该路径下的`rootCA.pem`文件,后缀改为`.crt`。
5. 运行[server.py](server.py),Windows下 `pythonw server.py`,Linux下 `nohup python server.py &`,即可实现后台运行。

Linux下也可使用`systemd`实现开机自启动,创建`/etc/systemd/system/read_captcha.service`文件,内容如下:

```ini
[Unit]
Description=readcaptcha
After=network.target

[Service]
Type=idle
User=root
Restart=on-failure
RestartSec=60s
WorkingDirectory=/path/to/read_captcha
ExecStart=python sever.py

[Install]
WantedBy=multi-user.target
```

运行`systemctl enable read_captcha`即可实现开机自启动,`systemctl start read_captcha`启动服务。

### 客户端

1. 双击安装之前保存的根证书 `rootCA.crt` 至可信任根证书颁发机构。
2. 在浏览器中访问 `https://xxx.xxx.xxx.xxx`,若提示不安全,说明证书配置失败;
![证书配置失败](img/证书配置失败.png)
3. 若正确提示 `Welcome to the Captcha Server! Post your captcha to /api`,说明证书配置成功。
![证书配置成功](img/证书配置成功.png)
4. 修改 [send_captcha.js L20](send_captcha.js#L20) 中的 `url` 变量为你的服务器地址,并在 Tampermonkey 中安装。
5. 此时访问 [统一身份认证](https://authserver.nju.edu.cn/authserver/login) ,即可自动填充验证码。

## 有域名和SSL证书使用

### 服务器

1. 在服务器上安装nginx,配置SSL证书。
2. 使用docker运行,可自定义端口:

```bash
docker run -d --restart=always --name readcaptcha \
-e PORT=12345 \
-p 127.0.0.1:12345:12345 \
do1e/readcaptcha:latest
```
3. nginx配置示例:

```nginx
server {
listen 443 ssl;
listen [::]:443 ssl;
server_name example.com;
access_log /var/log/nginx/readcaptcha.access.log;
error_log /var/log/nginx/readcaptcha.error.log;
location / {
proxy_pass http://127.0.0.1:12345;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Real-PORT $remote_port;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
```

### 客户端

1. 修改 [send_captcha.js L20](send_captcha.js#L20) 中的 `url` 变量为你的服务器地址,并在 Tampermonkey 中安装。
2. 此时访问 [统一身份认证](https://authserver.nju.edu.cn/authserver/login) ,即可自动填充验证码。