1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 更新 【2021.04.29】 目前支持世纪互联、Google Drive,预计后期会添加对Mega,Telegram等平台的支持 【2021.04.02】 目前同时支持国际版、个人版(家庭版)。 【2021.04.01】 修复授权失败、上传文件大小为0等问题。 现已支持arm、x86、x64平台的系统。 【2021.03.27】 新增多线程上传、MacOS客户端。 修复了一个致命bug,建议之前装过的更新下程序。 功能 支持上传文件和文件夹到指定目录,并保持上传前的目录结构。 支持命令参数使用,方便外部程序调用。 支持自定义上传分块大小。 支持多线程上传(多文件同时上传)。 支持根据文件大小动态调整重试次数,对抗不好的网络环境。 可以使用Telegram Bot实时监控上传进度 Github地址:https://github.com/gaowanliang/LightUploader
萌咖大佬写了一个 非常好的版本 ,可惜并没有开源,而且已经好久都没有更新了。这个项目作为从 DownloadBot 中独立出来的一个简易上传工具,旨在用更轻量化的方式让在各种平台都能快速的向各个网络硬盘上传数据。
这里只详细说下Linux的用法,Windows后面大概说下。
Windows、MacOS系统下载地址→传送门 ,直接将程序下载到本地后,按照下面方法进行授权、初始化,然后就可以使用命令上传了。
授权认证 点击右侧URL登录并授权,授权地址→【国际版、个人版(家庭版)】 ,【世纪互联】 ,Google Drive的授权链接是实时生成的,下面会说。
授权后会获取一个localhost开头打不开的链接,这里复制好整个链接地址,包括localhost。
安装LightUploader 打开这个界面,选择适合你系统的版本:https://github.com/gaowanliang/LightUploader/releases
这里以Linux 64位为例,当前最新版本为v2.0,应该下载 LightUploader_Linux_x86_64.tar.gz 这个文件
1 2 3 4 5 6 7 8 9 10 wget https://github.com/gaowanliang/LightUploader/releases/download/v2.0/LightUploader_Linux_x86_64.tar.gz tar -zxvf LightUploader_Linux_x86_64.tar.gz -C /usr/local /bin/ chmod +x /usr/local /bin/LightUploader ln -s /usr/local /bin/LightUploader /usr/bin/LightUploader
初始化配置 1 2 3 4 5 6 7 8 9 10 11 LightUploader -a "url" -l zh-CN LightUploader -a "url" -v 1 -l zh-CN LightUploader -a "url" -v 2 -l zh-CN LightUploader -v 3 -l zh-CN
如果提示注册成功
类似信息,则初始化成功。
使用命令 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 Usage of LightUploader: -a string Setup and Init auth.json. -b string -c string -r string -l string -f string -t string -to int -tgbot string -uid string -m int -v int
命令示例 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 LightUploader -c xxx.json -f "mm00.jpg" LightUploader -c xxx.json -f "Download" LightUploader -c xxx.json -f "Download" -r "Test" LightUploader -c xxx.json -t 10 -f "Download" LightUploader -c xxx.json -t 10 -f "Download" -m 1 LightUploader -c xxx.json -t 10 -f "Download" -to 30 LightUploader -c xxx.json -t 10 -f "Download" -tgbot "123456:xxxxxxxx" -uid 123456789 LightUploader -c xxx.json -t 10 -f "Download" -tgbot "1" LightUploader -c xxx.json -t 15 -b 20 -f "Download"
/urs/local/auth.json
为初始化时,生成的*.json绝对路径地址,本文默认/root/auth.json
,自行调整。
Aria2自动上传 同样的这里也会提供个配套的Aria2自动上传脚本 上传脚本代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 #!/bin/bash GID="$1 " ; FileNum="$2 " ; File="$3 " ; MaxSize="157286400" ; Thread="3" ; Block="20" ; RemoteDIR="" ; LocalDIR="/www/download/" ; Uploader="/usr/local/bin/LightUploader" ; Config="/root/auth.json" ; if [[ -z $(echo "$FileNum " |grep -o '[0-9]*' |head -n1) ]]; then FileNum='0' ; fi if [[ "$FileNum " -le '0' ]]; then exit 0; fi if [[ "$# " != '3' ]]; then exit 0; fi function LoadFile (){ if [[ ! -e "${Uploader} " ]]; then return ; fi IFS_BAK=$IFS IFS=$'\n' tmpFile="$(echo "${File/#$LocalDIR} " |cut -f1 -d'/') " FileLoad="${LocalDIR} ${tmpFile} " if [[ ! -e "${FileLoad} " ]]; then return ; fi ItemSize=$(du -s "${FileLoad} " |cut -f1 |grep -o '[0-9]*' |head -n1) if [[ -z "$ItemSize " ]]; then return ; fi if [[ "$ItemSize " -ge "$MaxSize " ]]; then echo -ne "\033[33m${FileLoad} \033[0mtoo large to spik.\n" ; return ; fi ${Uploader} -c "${Config} " -t "${Thread} " -b "${Block} " -f "${FileLoad} " -r "${RemoteDIR} " if [[ $? == '0' ]]; then rm -rf "${FileLoad} " ; fi IFS=$IFS_BAK } LoadFile;
编辑好上传脚本后,可以检测下脚本编码是否正确,比如我脚本路径为/root/upload.sh
,使用命令:
如果无任何输出,则正确,反之输出类似$’r’: command not found错误,则需要转换下编码格式,具体步骤如下。
先安装dos2unix:
1 2 3 4 5 6 7 8 9 yum install dos2unix -y apt install dos2unix -y 再转换编码: dos2unix /root/upload.sh
Windows使用 这里就随便补充下Windows使用,先下载程序文件,下载地址→传送门 。
比如我将exe文件放到D盘,然后使用Win+R,输入CMD运行,调出窗口后,使用命令:
1 2 3 4 5 6 7 8 9 10 11 12 #进入D盘 cd /d D:\#国际版初始化,将url换成你上面复制的授权地址,包括http://loaclhost。 LightUploader.exe -a "url" -l zh-CN #个人版(家庭版)初始化,将url换成你上面复制的授权地址,包括http://loaclhost。 LightUploader.exe -a "url" -v 1 -l zh-CN #世纪互联初始化,将url换成你上面复制的授权地址,包括http://loaclhost。 LightUploader.exe -a "url" -v 2 -l zh-CN
然后上传命令和上面一样,只需要把LightUploader
改成LightUploader.exe
即可。
更换自己的API 我本来想着做一个简单更换API的方法,但是思来想去不知道怎么弄好,因为本身这个软件是单文件的,首次就需要API进行登录,这个API存储在哪里就很麻烦了,索性就不弄了,和大家说一下如何通过自行编译的方式更换自己的API。
使用VSCode/Goland等工具,进行全局替换,需要查找的值有这几个:
OneDrive 国际版/家庭版 客户端ID:ad5e65fd-856d-4356-aefc-537a9700c137
(国际版不需要密钥)
OneDrive 世纪互联 客户端ID:4fbf37cf-dc83-4b60-b6c1-6230546e247b
OneDrive 世纪互联 密钥:y-L73QIBxO_UmJvOVw8YMlX~8B_h4D6zzT
Google Drive 授权文件:见gdUpload.go#L224
因为GoogleDrive还是测试版,目前传文件很不稳定,这里先简单的说一下OneDrive怎么弄
Azure.com 应用注册
Azure.cn (世纪互联) 应用注册
没有说明的随意填写即可
选择 任何组织目录(任何 Azure AD 目录 - 多租户)中的帐户
重定向 url 键入并保存 http://localhost/onedrive-login
保存 客户端ID
去 证书和密码 ,添加并保存 客户端密码
(国际版不需要)
API 权限(Microsoft Graph)添加 offline_access
, Files.ReadWrite.All
, User.Read
三个权限。
下载好源代码后,使用上面说的工具,按下Ctrl+Shift+H
,根据自己的情况将上面的值直接全局替换即可,因为我软件的依赖库都直接绑到代码里了,所以装好golang直接go build -o LightUploader .
编译即可,不会出现依赖问题。