OneDriveUploader:一个实用的实现VPS上传文件至onedrive网盘的工具

项目地址:https://github.com/MoeClub/OneList/tree/master/OneDriveUploader

1、获取授权

国际版、个人版点此跳转

CN版(世纪互联)点此跳转

授权后你将会在浏览器地址框获得一个 localhost 开头的链接,你需要将它完整地复制下来,稍后将会用到。

2、开始安装

64位系统下载并将其拷贝至/usr/local/bin/

wget https://raw.githubusercontent.com/MoeClub/OneList/master/OneDriveUploader/amd64/linux/OneDriveUploader -P /usr/local/bin/

32位系统下载并将其拷贝至/usr/local/bin/

wget https://raw.githubusercontent.com/MoeClub/OneList/master/OneDriveUploader/i386/linux/OneDriveUploader -P /usr/local/bin/

arm架构位系统下载并将其拷贝至/usr/local/bin/

wget https://raw.githubusercontent.com/MoeClub/OneList/master/OneDriveUploader/arm/linux/OneDriveUploader -P /usr/local/bin/

给予权限

chmod +x /usr/local/bin/OneDriveUploader
3、开始授权

国际版

将”http://localhost….”换成你上面复制的授权地址,包括http://localhost

OneDriveUploader -a "http://localhost...."

个人版(家庭版)

将”http://localhost….”换成你上面复制的授权地址,包括http://locallhost

OneDriveUploader -ms -a "http://localhost...."

中国版(世纪互联)

将”http://localhost….”换成你上面复制的授权地址

OneDriveUploader -cn -a "http://localhost...."

由于我使用的是商业版od,因此使用的是国际版授权命令。回车后如出现:

Init config file: /root/auth.json

则表示初始化成功

3、命令的使用
Usage of OneDriveUploader:   
  -a string         
     // 初始化授权         
     Setup and Init auth.json.   
  -b string         
     // 自定义上传分块大小, 可以提高网络吞吐量, 受限于磁盘性能和网络速度.         
     Set block size. Unit: M; 5 <=b<=60;   
  -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.

以下为软件作者所展示的命令使用示例

#一些示例: 
# 将同目录下的 mm00.jpg 文件上传到 OneDrive 网盘根目录 
OneDriveUploader  -c /root/auth.json -s "mm00.jpg" 

# 将同目录下的 mm00.jpg 文件上传到 OneDrive 网盘根目录,并改名为 mm01.jpg 
OneDriveUploader  -c /root/auth.json -s "mm00.jpg" -n "mm01.jpg" 

# 将同目录下的 Download 文件夹上传到 OneDrive 网盘根目录 
OneDriveUploader  -c /root/auth.json -s "Download"  

# 将同目录下的 Download 文件夹上传到 OneDrive 网盘Test目录中 
OneDriveUploader  -c /root/auth.json -s "Download" -r "Test" 

# 将同目录下的 Download 文件夹上传到 OneDrive 网盘Test目录中, 使用 10 线程 
OneDriveUploader -t 10 -s "Download" -r "Test" 

# 将同目录下的 Download 文件夹上传到 OneDrive 网盘Test目录中, 使用 15 线程, 并设置分块大小为 20M 
OneDriveUploader -t 15 -b 20 -s "Download" -r "Test" 

# 将同目录下的 Download 文件夹上传到 OneDrive 网盘Test目录中, 使用配置文件中的线程参数和分块大小参数 
OneDriveUploader -f -c "/root/auth.json" -s "Download" -r "Test" 

# 将同目录下的 Download 文件夹上传到 OneDrive 网盘Test目录中, 使用配置文件中的线程参数和分块大小参数,并跳过上传网盘中已存在的同名文件 
OneDriveUploader -f -c "/root/auth.json" -skip -s "Download" -r "Test"

我常用的是下面的这个简单的命令,将目录上传至onedrive的根目录下

OneDriveUploader -c /root/auth.json -t 5 -s "/floder"
配合Aria2实现自动上传

以下所列脚本已实践过,是可以实现预期目标的。

#!/bin/bash

GID="$1";
FileNum="$2";
File="$3";
MaxSize="15728640";
Thread="3";  #默认3线程,自行修改
Block="20";  #默认分块20m,自行修改
RemoteDIR="";  #上传到Onedrive的路径,默认为根目录,如果要上传到MOERATS目录,""里面请填成MOERATS
LocalDIR="/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;

编辑并上传好脚本后需检测脚本是否能正常运行

bash /脚本所在目录/脚本名.sh

如无任何输出则为正常运行;如输出 $’r’: command not found 的错误则需要安装dos2unix来转换编码格式。

#CentOS系统
yum install dos2unix -y

#Debian/Ubuntu系统
apt install dos2unix -y

转换编码

dos2unix /脚本所在目录/脚本名.sh
配置Aria2以实现自动上传

对脚本进行授权

chmod +x /脚本所在目录/脚本名.sh

接下来需要去到Aria2的配置文件(通常默认为在/root/.aria2目录下的.conf结尾的文件)中添加一行:

on-download-complete=/脚本所在目录/脚本名.sh

重启Aria2配置即生效。

留下评论

您的电子邮箱地址不会被公开。 必填项已用 * 标注