说明:博主很久前分享过使用Shell
写的OneDrive
网盘上传工具→传送门,不过由于使用的是旧API
,而微软使旧API
强制过时,也就是强制不让用了,不让授权了,导致全部人无法使用,所以在外搬砖多日的萌咖大佬重新出山,使用Golang
基于新的API
写了个效率更高的上传工具,同时也修复了各种Shell
版本遗留下来的小问题,该版本特点就是授权简单,无需依赖,单文件。同样的也可以配合Aria2
一起自动上传,这里就再分享下,方便下有需求的人。
更新
【2019.12.21】
支持跳过网盘中已存在的同名文件。
【2019.12.20】
目前同时支持国际版、个人版(家庭版)、中国版(世纪互联)。
【2019.12.15】
修复授权失败、上传文件大小为0等问题。
现已支持arm、x86、x64平台的系统。
【2019.11.29】
新增多线程上传、MacOS客户端。
修复了一个致命bug,建议之前装过的更新下程序。
功能
- 支持上传文件和文件夹到指定目录,并保持上传前的目录结构。
- 支持命令参数使用,方便外部程序调用。
- 支持自定义上传分块大小。
- 支持多线程上传(多文件同时上传)。
- 支持根据文件大小动态调整重试次数,对抗不好的网络环境。
使用
Github地址:https://github.com/MoeClub/OneList/tree/master/OneDriveUploader
这里只详细说下Linux
的用法,Windows
后面大概说下。
Windows
、MacOS
系统下载地址→传送门,直接将程序下载到本地后,按照下面方法进行授权、初始化,然后就可以使用命令上传了。
1、授权认证
点击右侧URL
登录并授权,授权地址→【国际版、个人版(家庭版)】、【中国版(世纪互联)】。
授权后会获取一个localhost
开头打不开的链接,这里复制好整个链接地址,包括localhost
。
2、安装OneDriveUploader
#64位系统下载
wget https://raw.githubusercontent.com/MoeClub/OneList/master/OneDriveUploader/amd64/linux/OneDriveUploader -P /usr/local/bin/
#32位系统下载
wget https://raw.githubusercontent.com/MoeClub/OneList/master/OneDriveUploader/i386/linux/OneDriveUploader -P /usr/local/bin/
#arm架构下载
wget https://raw.githubusercontent.com/MoeClub/OneList/master/OneDriveUploader/arm/linux/OneDriveUploader -P /usr/local/bin/
#给予权限
chmod +x /usr/local/bin/OneDriveUploader
3、初始化配置
#国际版,将url换成你上面复制的授权地址,包括http://loaclhost。
OneDriveUploader -a "url"
#个人版(家庭版),将url换成你上面复制的授权地址,包括http://loaclhost。
OneDriveUploader -ms -a "url"
#中国版(世纪互联),将url换成你上面复制的授权地址,包括http://loaclhost。
OneDriveUploader -cn -a "url"
如果提示Init config file: /path/to/file/auth.json
类似信息,则初始化成功。
4、使用命令
Usage of OneDriveUploader:
-a string
// 初始化授权
Setup and Init auth.json.
-b string
// 自定义上传分块大小, 可以提高网络吞吐量, 受限于磁盘性能和网络速度.
Set block size. [Unit: M; 5<=b<=60;] (default "10")
-c string
// 配置文件路径
Config file. (default "auth.json")
-n string
// 上传单个文件时,在网盘中重命名
Rename file on upload to remote.
-r string
// 上传到网盘中的某个目录, 默认: 根目录
Upload to reomte path.
-s string
// *必要参数, 要上传的文件或文件夹
Upload item.
-t string
// 线程数, 同时上传文件的个数. 默认: 2
Set thread num. (default "2")
-f
// 开关(推荐)
// 加上 -f 参数,强制读取 auth.json 中的块大小配置和多线程配置.
// 不加 -f 参数, 每次覆盖保存当前使用参数到 auth.json 配置文件中.
Force Read config form config file. [BlockSize, ThreadNum]
-skip
// 开关
// 跳过上传网盘中已存在的同名文件. (默认不跳过)
Skip exist file on remote.
-cn
// 开关
// 授权中国版(世纪互联), 需要此参数.
OneDrive by 21Vianet.
-ms
// 开关
// 授权个人版(家庭版), 需要此参数.
OneDrive by Microsoft.
5、命令示例
#将当前目录下的mm00.jpg文件上传到OneDrive网盘根目录
OneDriveUploader -c /path/to/file/auth.json -s "mm00.jpg"
#将当前目录下的mm00.jpg文件上传到OneDrive网盘根目录,并改名为mm01.jpg
OneDriveUploader -c /path/to/file/auth.json -s "mm00.jpg" -n "mm01.jpg"
#将当前目录下的Download文件夹上传到OneDrive网盘根目录
OneDriveUploader -c /path/to/file/auth.json -s "Download"
#将当前目录下的Download文件夹上传到OneDrive网盘Test目录中
OneDriveUploader -c /path/to/file/auth.json -s "Download" -r "Test"
#将同目录下的Download文件夹上传到OneDriv网盘Test目录中,使用10线程
OneDriveUploader -c /path/to/file/auth.json -t 10 -s "Download" -r "Test"
#将同目录下的Download文件夹上传到OneDrive网盘Test目录中,使用15线程,并设置分块大小为20M
OneDriveUploader -c /path/to/file/auth.json -t 15 -b 20 -s "Download" -r "Test"
/path/to/file/auth.json
为初始化时,生成的auth.json
绝对路径地址,本文默认/root/auth.json
,自行调整。
注意:如果你之前上传手动中断过,再上传的时候,请使用-skip
参数,默认会跳过你已经上传过的文件/文件夹。
Aria2自动上传
同样的这里也会提供个配套的Aria2
自动上传脚本,上传配置方法参考→传送门。
上传脚本代码如下:
#!/bin/bash
GID="$1";
FileNum="$2";
File="$3";
MaxSize="15728640";
Thread="3"; #默认3线程,自行修改,服务器配置不好的话,不建议太多
Block="20"; #默认分块20m,自行修改
RemoteDIR=""; #上传到Onedrive的路径,默认为根目录,如果要上传到MOERATS目录,""里面请填成MOERATS
LocalDIR="/www/download/"; #Aria2下载目录,记得最后面加上/
Uploader="/usr/local/bin/OneDriveUploader"; #上传的程序完整路径,默认为本文安装的目录
Config="/root/auth.json"; #初始化生成的配置auth.json绝对路径,参考第3步骤生成的路径
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}" -s "${FileLoad}" -r "${RemoteDIR}" -skip
if [[ $? == '0' ]]; then
rm -rf "${FileLoad}";
fi
IFS=$IFS_BAK
}
LoadFile;
编辑好上传脚本后,可以检测下脚本编码是否正确,比如我脚本路径为/root/upload.sh
,使用命令:
bash /root/upload.sh
如果无任何输出,则正确,反之输出类似$'r': command not found
错误,则需要转换下编码格式,具体步骤如下。
先安装dos2unix
:
#CentOS系统
yum install dos2unix -y
#Debian/Ubuntu系统
apt install dos2unix -y
再转换编码:
#后面为脚本路径
dos2unix /root/upload.sh
Windows使用
这里就随便补充下Windows
使用,先下载程序文件,下载地址→传送门。
比如我将exe
文件放到D
盘,然后使用Win+R
,输入CMD
运行,调出窗口后,使用命令:
#进入D盘
cd /d D:\
#国际版初始化,将url换成你上面复制的授权地址,包括http://loaclhost。
OneDriveUploader.exe -a "url"
#个人版(家庭版)初始化,将url换成你上面复制的授权地址,包括http://loaclhost。
OneDriveUploader.exe -ms -a "url"
#中国版(世纪互联)初始化,将url换成你上面复制的授权地址,包括http://loaclhost。
OneDriveUploader.exe -cn -a "url"
然后上传命令和上面一样,只需要把OneDriveUploader
改成OneDriveUploader.exe
即可。
最后经测试,该版本的上传已经完全能应对各种稀奇古怪的字符问题,如果有问题可以回复下,贴上报错代码,方便修复。
感谢博主,已用上。速度还不错
给萌神汇报一下,终于搞定了。萌神
也建议萌神把这几个帖子合起来。好难找啊。。
这称呼浮夸了
aria2.log文件是空的。而且在两个vps上试过了,确实是传不上去。整个脚本只改了一下aria2下载目录,我的是/root/download 其他的都没动连文件都是GDupload.sh 直接改文件内容,之前的脚本可以上传,这个新版本传不上去,手动可以传上去。aria2版本是1.35.0.
下载目录后面加一个/,正确是/root/download/。
加了。看到后面的注释了,一直都有/
!/bin/bashGID="$1";
FileNum="$2";
File="$3";
MaxSize="15728640";
Thread="2"; #默认3线程,自行修改,服务器配置不好的话,不建议太多
Block="20"; #默认分块20m,自行修改
RemoteDIR=""; #上传到Onedrive的路径,默认为根目录,如果要上传到MOERATS目录,""里面请填成MOERATS
LocalDIR="/root/download/"; #Aria2下载目录,记得最后面加上/
Uploader="/usr/local/bin/OneDriveUploader"; #上传的程序完整路径,默认为本文安装的目录
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(){
echo -ne "\033[33m${FileLoad} \033[0mtoo large to spik.\n"; return;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
fi
rm -rf "${FileLoad}";${Uploader} -c "${Config}" -t "${Thread}" -b "${Block}" -s "${FileLoad}" -r "${RemoteDIR}"
if [[ $? == '0' ]]; then
fi
IFS=$IFS_BAK
}
LoadFile;
缺个参数,我后面加了个Config="/root/auth.json";,你看下
这个参数也有。因为试了不行所以我把这个删了把auth.json放到/usr/local/bin/试了一下,依然不行,所以复制了是这样,有这个参数也是不行。传不上去
你手动运行下上传脚本bash GDupload.sh,看有没有编码报错问题,其它我就不是很清楚了,目前就这种可能性最大了。
OneDriveUploader -c "/home/demo/auth.json" -a 这样初始化成功Init config file: /home/demo/auth.json,但实际BT下找不到json文件,并且上传也提示Config: /home/demo/auth.json not found ,是什么原因?不能创建json?(默认不加参数c制定目录也是无法找到auth.json)
然而本地上传带宽永远是硬伤
一般都是在VPS上用
之前的OneDrive好像还要管理员授权,如果是教育邮箱撸的5T的话
试了,这个新的还是不行,依然传不上去,这个能看到LOG么?好排查一下问题
我测试了下,好像没问题,你看下aria2日志,一般默认aria2.log文件,你找不到路径的话,使用find / -name aria2.log命令查找下。
手动上传可以,但是aria2下载完上传传不上去。以前的那个脚本版本可以传上去
我也是一样的问题,我手动运行脚本不会出错,手动上传也是可以的,就是自动不能上传
自动的话,要是授权啥的配置都做好了,还没传,那有没有aria2.log日志?最下面应该有
这个忘了指定配置文件路径,好像默认从/usr/local/bin目录调用,脚本改了下,你再试试
用的也是新的这个带配置文件路径的,运行它什么提示都不会有直接会跳回#号,但是就是自动不行
另外请大神帮忙看看这个,https://github.com/xiaomi-sa/smartdns,看vps装这个能不能优化访问速度。谢谢。
这个都6年前的项目了,还有用不
我win10打开软件没反应怎么搞
win10直接在CMD里面调用,直接打开是不行的,我等会补到文章里吧。
大神真是厉害,这么快就有解决新版API的办法。
给萌鼠赞一个
你要给萌咖大佬点赞才行