深澜校园网登录脚本 Go 语言版。GO 语言可以直接交叉编译出 mips 架构可执行程序(路由器)(主流平台更不用说了),从而免除安装环境。
主要登录逻辑来自: https:/coffeehat/BIT-srun-login-script
OpenWrt 特供插件: Mmx233/BitSrunLoginGo_Openwrt ,压缩了 binary 文件,节省闪存空间
编译结果为可执行文件,下载 release 或编译后直接启动即可
可以通过添加启动参数 --config
指定配置文件路径,默认为当前目录的 Config.yaml
支持 json
、yaml
、yml
、toml
、hcl
、tfvars
等,仅对 json
和yaml
进行了优化与测试
./autoLogin --config=/demo/i.json
首次运行将自动生成配置文件,首次使用建议开启调试日志(settings.log.debug_level
)
Config.yaml 说明:
form:
domain: www.msftconnecttest.com #登录地址 ip 或域名
username: "" #账号
usertype: cmcc #运营商类型,详情看下方
password: "" #密码
meta: #登录参数
"n": "200"
type: "1"
acid: "5"
enc: srun_bx1
settings:
basic: #基础设置
https: false #访问校园网 API 时使用 https 协议
skip_cert_verify: false #跳过证书有效校验
timeout: 5 #网络请求超时时间(秒,正整数)
interfaces: "" #网卡名称正则(注意转义),如:eth0\.[2-3],不为空时为多网卡模式
guardian: #守护模式(后台常驻)
enable: false
duration: 300 #网络检查周期(秒,正整数)
daemon: #后台挂起(不建议 windows 使用,windows 请使用系统计划任务)
enable: false
path: .BitSrun #守护监听文件路径,用于确保只有单守护运行
log:
debug_level: false #打印调试日志
write_file: false #写日志文件
log_path: ./ #日志文件存放目录路径
log_name: "" #指定日志文件名
登录参数从原网页登陆时对 /srun_portal
的请求抓取,抓取时请把浏览器控制台的 preserve log
(保留日志)启用。
运营商类型在原网页会被自动附加在账号后,请把 @
后面的部分填入 user_type
,没有则留空(删掉默认的)
镜像:mmx233/bitsrunlogin-go:latest
支持 linux/amd64、linux/386、linux/arm64、linux/arm/v7 架构(windows 的 WSL2 版 docker 也算 Linux)
直接使用:
配置文件挂载至 /data/Config.yaml
,若需更改配置文件类型,可以使用 --entrypoint 覆写启动参数
docker run -v path_to_config:/data/Config.yaml mmx233/bitsrunlogin-go:latest
自行构建:
如果需要在其他系统或架构使用,可能需要更改构建层与底层镜像,目前使用的 alpine 并不支持 linux 之外的系统
git clone https:/Mmx233/BitSrunLoginGo.git
cd BitSrunLoginGo
docker build . --file Dockerfile --tag mmx233/bitsrunlogin-go:latest
请安装最新版 golang
直接编译本系统可执行程序:
git clone https:/Mmx233/BitSrunLoginGo.git
cd BitSrunLoginGo
go build
或者使用经过优化的构建命令:
go build -gcflags=-trimpath=$GOPATH -asmflags=-trimpath=$GOPATH -ldflags "-s -w -extldflags '-static'"
交叉编译(Linux):
export GOGGC=0
export GOOS=windows #系统
export GOARCH=amd64 #架构
go build -gcflags=-trimpath=$GOPATH -asmflags=-trimpath=$GOPATH -ldflags "-s -w -extldflags '-static'"
交叉编译(Powershell):
$env:GOGGC=0
$env:GOOS='linux' #系统
$env:GOARCH='amd64' #架构
go build -gcflags=-trimpath=$GOPATH -asmflags=-trimpath=$GOPATH -ldflags "-s -w -extldflags '-static'"
golang 支持的系统与架构请自行查询
*本项目使用了 AGPL V3 许可证,请酌情引用
示例:
package main
import (
"github.com/Mmx233/BitSrunLoginGo/v1"
)
func main() {
//具体用法请查看struct注释
conf:=&BitSrun.Conf{
Https: false,
Client: nil,
LoginInfo: BitSrun.LoginInfo{
Form: &BitSrun.LoginForm{
Domain: "",
UserName: "",
UserType: "",
PassWord: "",
},
Meta: &BitSrun.LoginMeta{
N: "",
Type: "",
Acid: "",
Enc: "",
},
},
}
online, clientIP, e := BitSrun.LoginStatus(conf)
if e!=nil {
panic(e)
}
if !online {
e=BitSrun.DoLogin(clientIP, conf)
if e!=nil {
panic(e)
}
}
}