介绍:今天就带给大家一款由 萌咖 大佬使用 Golang 基于新的API写的一个效率很高的 OneDrive 上传工具 OneDriveUploader ,同时也修复了各种Shell版本遗留下来的小问题,该版本特点就是授权简单,无需依赖,单文件。同样的也可以配合Aria2一起自动上传,这里就再分享下,方便下有需求的人。

  • Github

功能

  • 支持 国际版, 个人版(家庭版), 中国版(世纪互联).
  • 支持上传文件和文件夹到指定目录,并保持上传前的目录结构.
  • 支持命令参数使用, 方便外部程序调用.
  • 支持自定义上传分块大小.
  • 支持多线程上传(多文件同时上传).
  • 支持根据文件大小动态调整重试次数
  • 支持跳过网盘中已存在的同名文件.

授权

通过下面URL登录你的OneDrive

  • 国际版, 个人版(家庭版)
  • 中国版(世纪互联)

登录授权后在浏览器地址栏中获取以 http://loaclhost 开头的整个url内容,不要关闭浏览器,或者复制下来保存

安装

下载上传脚本

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

下载不了看 解决GitHub的raw.githubusercontent.com无法连接问题

初始化配置文件

# 国际版
OneDriveUploader -a "url"
# 个人版(家庭版)
OneDriveUploader -ms -a "url"
# 中国版(世纪互联)
OneDriveUploader -cn -a "url"

将获取的完整url内容替换命令中的 url 三个字母

每次产生的 url 只能用一次, 重试请重新获取 url

此操作将会自动初始化的配置文件

提示 Init config file: '/path/to/auth.json' 则成功

配置文件

初始化的配置文件成功会在你的脚本下载文件同目录(我是root目录)生成auth.json文件

可以自行修改配置文件

{
    // 授权令牌
    "RefreshToken": "1234564567890ABCDEF",
    // 最大线程数.(同时上传文件的数量)
    "ThreadNum": "2",
    // 最大上传分块大小.(每次上传文件的最大分块大小,网络不好建议调低. 单位:MB)
    "BlockSize": "10",
    // 最大单文件大小.(目前: 个人版(家庭版)单文件限制为100GB; 其他版本单文件限制为15GB,微软将逐步更新为100GB. 单位:GB)
    "SigleFile": "100",
    // 缓存刷新间隔.
    "RefreshInterval": 1500,
    // 如果是中国版(世纪互联), 此项应为 true.
    "MainLand": false,
    // 如果是家庭版或者个人免费版, 此项应为 true.
    "MSAccount": true
}

命令参数

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.

使用案例

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

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

# 将同目录下的 Download 文件夹上传到 OneDrive 网盘根目录
OneDriveUploader -s "Download" 

# 将同目录下的 Download 文件夹上传到 OneDrive 网盘Test目录中
OneDriveUploader -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 "/urs/local/auth.json" -s "Download" -r "Test"

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

比如我上传一个在root文件夹下的leanote-linux-amd64-v2.4.bin.tar.gz文件

OneDrive查看

文件太,文件夹文件太?那就后台上传

nohup 你的上传命令 &
//例如:nohup OneDriveUploader -s "leanote-linux-amd64-v2.4.bin.tar.gz" &

先删掉

上传

查看

nohup命令会在你的上传路径生成一个nohup.out文件,可以在里面看你的上传状态,或者报错信息

注意

  • 多次尝试后, 无失败的上传文件. 退出码为 0 .
  • 最终还有失败的上传文件会详细列出上传失败项. 退出码为 1.

配合使用

  • 支持边下边播、无版权限制和自动上传的BT离线下载程序
  • 利用云函数无服务器部署OneDrive分享网盘
  • youtube-dl:一个命令行视频下载利器
  • 多种功能强大的BT离线下载程序Docker镜像及安装
  • 大盘鸡搭建jellyfin私人影院

[1]: https://github.com/MoeClub/OneList/tree/master/OneDriveUploader [2]: https://login.microsoftonline.com/common/oauth2/v2.0/authorize?client_id=78d4dc35-7e46-42c6-9023-2d39314433a5&response_type=code&redirect_uri=http://localhost/onedrive-login&response_mode=query&scope=offline_access%20User.Read%20Files.ReadWrite.All [3]: https://login.chinacloudapi.cn/common/oauth2/v2.0/authorize?client_id=dfe36e60-6133-48cf-869f-4d15b8354769&response_type=code&redirect_uri=http://localhost/onedrive-login&response_mode=query&scope=offline_access%20User.Read%20Files.ReadWrite.All [4]: https://jscdn.cachefly.net/web/wxiou/20200703104019.png [5]: https://jscdn.cachefly.net/web/wxiou/20200703104622.png [6]: https://jscdn.cachefly.net/web/wxiou/20200703104451.png [7]: https://blog.k6366.com.cn/index.php/archives/131/ [8]: https://jscdn.cachefly.net/web/wxiou/20200703104753.png [9]: https://jscdn.cachefly.net/web/wxiou/20200703105000.png [10]: https://jscdn.cachefly.net/web/wxiou/20200703105441.png [11]: https://jscdn.cachefly.net/web/wxiou/20200703105512.png [12]: https://jscdn.cachefly.net/web/wxiou/20200703105745.png [13]: https://jscdn.cachefly.net/web/wxiou/20200703110756.png [14]: https://jscdn.cachefly.net/web/wxiou/20200703110843.png [15]: https://jscdn.cachefly.net/web/wxiou/20200703111011.png [16]: https://blog.k6366.com.cn/index.php/archives/66/ [17]: https://blog.k6366.com.cn/index.php/archives/98/ [18]: https://blog.k6366.com.cn/index.php/archives/91/ [19]: https://blog.k6366.com.cn/index.php/archives/86/ [20]: https://blog.k6366.com.cn/index.php/archives/81/
最后修改:2020 年 07 月 24 日
如果觉得我的文章对你有用,请随意赞赏