Skip to content

一个从DownloadBot独立出的简单的全平台OneDrive网盘上传工具

Notifications You must be signed in to change notification settings

niu12503/OneDriveUploader

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OneDriveUploader

萌咖大佬写了一个非常好的版本,可惜并没有开源,而且已经好久都没有更新了。这个项目作为从DownloadBot中独立出来的一个简易上传工具,使得上传更加方便。同时会逐渐向萌咖的版本完善相关的功能,目前版本仅仅是从DownloadBot中独立的,只做了简单的功能。

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

授权

通过下面URL登录 (右键新标签打开)

国际版, 个人版(家庭版)

https://login.microsoftonline.com/common/oauth2/v2.0/authorize?client_id=ad5e65fd-856d-4356-aefc-537a9700c137&response_type=code&redirect_uri=http://localhost/onedrive-login&response_mode=query&scope=offline_access%20User.Read%20Files.ReadWrite.All

中国版(世纪互联)

初始化配置文件

# 国际版
OneDriveUploader -a "url"

# 个人版(家庭版)
OneDriveUploader -a "url" -v 1
# 中国版(世纪互联) 目前设计中,暂不可用
OneDriveUploader -a "url" -v 2

# 在浏览器地址栏中获取以 http://loaclhost 开头的整个url内容
# 将获取的完整url内容替换命令中的 url 三个字母
# 每次产生的 url 只能用一次, 重试请重新获取 url
# 此操作将会自动初始化的配置文件

使用

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.

  -f string
        // *必要参数, 要上传的文件或文件夹
        Upload item.
  -t string
        // 线程数, 同时上传文件的个数. 默认: 3
        Set thread num. (default "3")
  
  //此参数未设计,暂不可用
  -force
        // 开关(推荐)
        // 加上 -f 参数,强制读取 auth.json 中的块大小配置和多线程配置.
        // 不加 -f 参数, 每次覆盖保存当前使用参数到 auth.json 配置文件中.
        Force Read config form config file. [BlockSize, ThreadNum]

  //此参数未设计,暂不可用
  -skip
        // 开关
        // 跳过上传网盘中已存在的同名文件. (默认不跳过)
        Skip exist file on remote.

  -tgbot string
        //使用Telegram机器人实时监控上传,此处需填写机器人的access token,形如123456789:xxxxxxxxx,输入时需使用双引号包裹
  -uid string
        // 使用Telegram机器人实时监控上传,此处需填写接收人的userID,形如123456789
  -v int
        // 选择版本,其中0为国际版,1为个人版(家庭版),默认为0

配置

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

示例

# 一些示例:

# 将同目录下的 mm00.jpg 文件上传到 OneDrive 网盘根目录
OneDriveUploader -c xxx.json -f "mm00.jpg"

# 将同目录下的 mm00.jpg 文件上传到 OneDrive 网盘根目录,并改名为 mm01.jpg(暂不可用)
OneDriveUploader  -c xxx.json -s "mm00.jpg" -n "mm01.jpg"

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

# 将同目录下的 Download 文件夹上传到 OneDrive 网盘Test目录中(暂不可用)
OneDriveUploader -c xxx.json -s "Download" -r "Test"

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

# 将同目录下的 Download 文件夹上传到 OneDrive 网盘根目录中, 使用 10 线程,同时使用 Telegram Bot 实时监控上传进度
OneDriveUploader -c xxx.json -t 10 -s "Download" -tgbot "123456:xxxxxxxx" -uid 123456789

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

# 将同目录下的 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"

注意

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

About

一个从DownloadBot独立出的简单的全平台OneDrive网盘上传工具

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 100.0%