diff --git a/docs/manual.md b/docs/manual.md new file mode 100644 index 0000000..6bf3fa6 --- /dev/null +++ b/docs/manual.md @@ -0,0 +1,1146 @@ +# 目录 +- [命令列表及说明](#命令列表及说明) + * [注意](#注意) + * [修改配置文件存储路径](#修改配置文件存储路径) + * [检测程序更新](#检测程序更新) + * [查看帮助](#查看帮助) + * [登录阿里云盘帐号](#登录阿里云盘帐号) + * [列出帐号列表](#列出帐号列表) + * [获取当前帐号](#获取当前帐号) + * [切换阿里云盘帐号](#切换阿里云盘帐号) + * [退出阿里云盘帐号](#退出阿里云盘帐号) + * [刷新Token](#刷新Token) + * [切换网盘(文件/相册)](#切换网盘) + * [获取网盘配额](#获取网盘配额) + * [切换工作目录](#切换工作目录) + * [输出工作目录](#输出工作目录) + * [列出目录](#列出目录) + * [下载文件/目录](#下载文件目录) + * [上传文件/目录](#上传文件目录) + * [手动秒传文件](#手动秒传文件) + * [创建目录](#创建目录) + * [删除文件/目录](#删除文件目录) + * [移动文件/目录](#移动文件目录) + * [重命名文件/目录](#重命名文件目录) + * [导出文件](#导出文件) + * [导入文件](#导入文件) + * [分享文件/目录](#分享文件目录) + + [设置分享文件/目录](#设置分享文件目录) + + [列出已分享文件/目录](#列出已分享文件目录) + + [取消分享文件/目录](#取消分享文件目录) + + [分享秒传链接](#分享秒传链接) + * [同步备份功能](#同步备份功能) + + [常用命令说明](#常用命令说明) + + [备份配置文件说明](#备份配置文件说明) + + [命令行启动](#命令行启动) + + [Linux后台启动](#Linux后台启动) + + [Windows后台启动](#Windows后台启动) + + [Docker运行](#Docker运行) + * [webdav文件服务](#webdav文件服务) + + [常用命令说明](#常用命令说明) + + [命令行启动](#命令行启动) + + [Linux后台启动](#Linux后台启动) + + [Docker运行](#Docker运行) + + [HTTPS配置](#HTTPS配置) + * [JavaScript插件](#JavaScript插件) + + [如何使用](#如何使用) + + [JS中内置的函数](#JS中内置的函数) + * [显示和修改程序配置项](#显示和修改程序配置项) +- [常见问题Q&A](#常见问题Q&A) + * [1. 如何获取RefreshToken](#1-如何获取RefreshToken) + * [2. 如何开启Debug调试日志](#2-如何开启Debug调试日志) + * [3. 解决 time: missing Location in call to Date 问题](#3-解决-missing-Location-in-call-to-Date-问题) + +# 命令列表及说明 +## 注意 + +命令的前缀 `aliyunpan` 为指向程序运行的全路径名 (ARGv 的第一个参数) + +直接运行程序时, 未带任何其他参数, 则程序进入cli交互模式, 进入cli模式运行以下命令时要把命令的前缀 `aliyunpan` 去掉! 即不需要输入`aliyunpan`。 + +cli交互模式支持按tab键自动补全命令. + +## 修改配置文件存储路径 +设置环境变量ALIYUNPAN_CONFIG_DIR并指定一个存在目录即可,注意目录需要是绝对路径 +``` +例如linux下面可以这样指定 + +export ALIYUNPAN_CONFIG_DIR=/home/tickstep/tools/aliyunpan/config +``` + +## 检测程序更新 +``` +aliyunpan update +``` + +## 查看帮助 +``` +aliyunpan help +``` +### 例子 +``` +列出程序支持的命令 +aliyunpan help + +查看login命令的帮助手册 +aliyunpan help login +``` + +## 登录阿里云盘帐号 + +### 登录 +当前支持使用RefreshToken进行登录。RefreshToken请参考 [1. 如何获取RefreshToken](#1-如何获取RefreshToken) 获取 +``` +aliyunpan login +``` + +### 例子 +``` +按照引导步骤登录 +aliyunpan login +请输入RefreshToken, 回车键提交 > 626a27b6193f4c5ca6ef0....... + +命令行指定RefreshToken登录 +aliyunpan login -RefreshToken=626a27b6193f4c5ca6ef0....... + +使用二维码方式进行登录,按照引导步骤进行 +aliyunpan login -QrCode +``` + + +## 列出帐号列表 + +``` +aliyunpan loglist +``` + +列出所有已登录的帐号 + +## 获取当前帐号 + +``` +aliyunpan who +``` + +## 切换阿里云盘帐号 + +切换已登录的帐号 +``` +aliyunpan su +``` +``` +aliyunpan su + +请输入要切换帐号的 # 值 > +``` + +## 退出阿里云盘帐号 + +退出当前登录的帐号 +``` +aliyunpan logout +``` + +程序会进一步确认退出帐号, 防止误操作. + +## 刷新Token +由于阿里云盘的RefreshToken是会过期的,为了延长最大过期时间,需要定期刷新Token,建议每小时刷新一次。 +调用该命令可以自动刷新RefreshToken并保存到配置文件中,但是有一个前提,即Token必须还没有过期,如果Token已经过期是无法刷新的则只能重新登录。 +``` +刷新当前登录用户 +aliyunpan token update + +刷新所有登录的用户 +aliyunpan token update -mode 2 +``` + +如果你的aliyunpan工具是在Linux中运行,则建议你使用crontab定时任务进行Token自动刷新,例如 +``` +每小时执行一次Token刷新任务 +*/60 * * * * //aliyunpan token update -mode 2 +``` + +## 切换网盘 +程序默认工作在文件网盘下,如需切换到相册网盘,可以使用本命令进行切换。 +``` +aliyunpan drive +``` +``` +aliyunpan drive + +输入要切换的网盘 # 值 > +``` + +## 获取网盘配额 + +``` +aliyunpan quota +``` +获取网盘的总储存空间, 和已使用的储存空间 + +## 切换工作目录 +``` +aliyunpan cd <目录> +``` + +### 例子 +``` +# 切换 /我的文档 工作目录 +aliyunpan cd /我的文档 + +# 切换 上级目录 +aliyunpan cd .. + +# 切换 根目录 +aliyunpan cd / + +``` + +## 输出工作目录 +``` +aliyunpan pwd +``` + +## 列出目录 + +列出当前工作目录的文件和目录或指定目录 +``` +aliyunpan ls +``` +``` +aliyunpan ls <目录> +``` + +### 可选参数 +``` +-driveId value 网盘ID +``` + +### 例子 +``` +# 列出 我的文档 内的文件和目录 +aliyunpan ls 我的文档 + +# 绝对路径 +aliyunpan ls /我的文档 + +# 详细列出 我的文档 内的文件和目录 +aliyunpan ll /我的文档 +``` + +## 下载文件/目录 +下载支持两种链接类型:1-默认类型 2-阿里ECS环境类型 +在普通网络下,下载速度可以达到10MB/s,在阿里ECS(必须是"经典网络"类型的机器)环境下,下载速度单文件可以轻松达到20MB/s,多文件可以达到100MB/s +![](./assets/images/download_file_ecs_speed_screenshot.gif) +![](./assets/images/download_file_speed_screenshot.gif) + +``` +aliyunpan download <网盘文件或目录的路径1> <文件或目录2> <文件或目录3> ... +aliyunpan d <网盘文件或目录的路径1> <文件或目录2> <文件或目录3> ... +``` + +### 可选参数 +``` + --ow overwrite, 覆盖已存在的文件 + --status 输出所有线程的工作状态 + --save 将下载的文件直接保存到当前工作目录 + --saveto value 将下载的文件直接保存到指定的目录 + -x 为文件加上执行权限, (windows系统无效) + -p value 指定下载线程数 (default: 0) + -l value 指定同时进行下载文件的数量 (default: 0) + --retry value 下载失败最大重试次数 (default: 3) + --nocheck 下载文件完成后不校验文件 + --exn value 指定排除的文件夹或者文件的名称,只支持正则表达式。支持排除多个名称,每一个名称就是一个exn参数 +``` + + +### 例子 +``` +# 设置保存目录, 保存到 D:\Downloads +# 注意区别反斜杠 "\" 和 斜杠 "/" !!! +aliyunpan config set -savedir D:/Downloads + +# 下载 /我的文档/1.mp4 +aliyunpan d /我的文档/1.mp4 + +# 下载 /我的文档 整个目录!! +aliyunpan d /我的文档 +``` + +下载的文件默认保存到 **程序所在目录** 的 download/ 目录, 支持设置指定目录, 重名的文件会自动跳过! + +通过 `aliyunpan config set -savedir ` 可以自定义保存的目录. + +支持多个文件或目录下载. + +自动跳过下载重名的文件! + +## 上传文件/目录 +上传支持两种链接类型:1-默认类型 2-阿里ECS环境类型 +在阿里ECS(必须是"经典网络"类型的机器)环境下,上传速度单文件可以轻松达到30MB/s,多文件可以达到100MB/s +![](../assets/images/upload_file_speed_screenshot.gif) + +``` +aliyunpan upload <本地文件/目录的路径1> <文件/目录2> <文件/目录3> ... <目标目录> +aliyunpan u <本地文件/目录的路径1> <文件/目录2> <文件/目录3> ... <目标目录> +``` + +### 例子: +``` +# 将本地的 C:\Users\Administrator\Desktop\1.mp4 上传到网盘 /视频 目录 +# 注意区别反斜杠 "\" 和 斜杠 "/" !!! +aliyunpan upload C:/Users/Administrator/Desktop/1.mp4 /视频 + +# 将本地的 C:\Users\Administrator\Desktop\1.mp4 和 C:\Users\Administrator\Desktop\2.mp4 上传到网盘 /视频 目录 +aliyunpan upload C:/Users/Administrator/Desktop/1.mp4 C:/Users/Administrator/Desktop/2.mp4 /视频 + +# 将本地的 C:\Users\Administrator\Desktop 整个目录上传到网盘 /视频 目录 +aliyunpan upload C:/Users/Administrator/Desktop /视频 + +## 下面演示文件或者文件夹排除功能 + +# 将本地的 C:\Users\Administrator\Video 整个目录上传到网盘 /视频 目录,但是排除所有的.jpg文件 +aliyunpan upload -exn "\.jpg$" C:/Users/Administrator/Video /视频 + +# 将本地的 C:\Users\Administrator\Video 整个目录上传到网盘 /视频 目录,但是排除所有的.jpg文件和.mp3文件,每一个排除项就是一个exn参数 +aliyunpan upload -exn "\.jpg$" -exn "\.mp3$" C:/Users/Administrator/Video /视频 + +以下是典型的排除特定文件或者文件夹的例子,注意:参数值必须是正则表达式 +1)排除@eadir文件或者文件夹:-exn "^@eadir$" +2)排除.jpg文件:-exn "\.jpg$" +3)排除.号开头的文件:-exn "^\." +4)排除~号开头的文件:-exn "^~" +5)排除 myfile.txt 文件:-exn "^myfile.txt$" +``` + +## 手动秒传上传文件 +通过秒传链接上传文件到网盘,秒传链接可以通过share命令获取 +``` +aliyunpan rapidupload <秒传链接1> <秒传链接2> <秒传链接3> ... +``` + +### 例子: +``` +# 如果秒传成功, 则保存到网盘路径 /file.dmg +aliyunpan rapidupload "aliyunpan://file.dmg|752FCCBFB2436A6FFCA3B287831D4FAA5654B07E|7005440|" + +# 如果秒传成功, 则保存到网盘路径 /pan_folder/file.dmg +aliyunpan rapidupload "aliyunpan://file.dmg|752FCCBFB2436A6FFCA3B287831D4FAA5654B07E|7005440|pan_folder" + +``` + +## 创建目录 +``` +aliyunpan mkdir <目录> +``` + +### 例子 +``` +aliyunpan mkdir test123 +``` + +## 删除文件/目录 +``` +aliyunpan rm <网盘文件或目录的路径1> <文件或目录2> <文件或目录3> ... +``` + +注意: 删除多个文件和目录时, 请确保每一个文件和目录都存在, 否则删除操作会失败. + +被删除的文件或目录可在网盘文件回收站找回. + +### 例子 +``` +# 删除 /我的文档/1.mp4 +aliyunpan rm /我的文档/1.mp4 + +# 删除 /我的文档/1.mp4 和 /我的文档/2.mp4 +aliyunpan rm /我的文档/1.mp4 /我的文档/2.mp4 + +# 删除 /我的文档 整个目录 !! +aliyunpan rm /我的文档 +``` + + +## 移动文件/目录 +``` +aliyunpan mv <文件/目录1> <文件/目录2> <文件/目录3> ... <目标目录> +``` + +注意: 移动多个文件和目录时, 请确保每一个文件和目录都存在, 否则移动操作会失败. + +### 例子 +``` +# 将 /我的文档/1.mp4 移动到 根目录 / +aliyunpan mv /我的文档/1.mp4 / +``` + +## 重命名文件/目录 +``` +aliyunpan rename <旧文件/目录名> <新文件/目录名> +``` + +注意: 重命名的文件/目录,如果指定的是绝对路径,则必须保证新旧的绝对路径在同一个文件夹内,否则重命名失败! + +### 例子 +``` +# 将 /我的文档/1.mp4 重命名为 /我的文档/2.mp4 +aliyunpan rename /我的文档/1.mp4 /我的文档/2.mp4 +``` + +## 导出文件 +导出文件主要是用于备份网盘的文件。通过该命令将网盘的文件元数据信息导出并保存到本地文件中,等到以后需要的时候再通过import命令导入到网盘中。 +``` +aliyunpan export <网盘文件/目录的路径1> <文件/目录2> <文件/目录3> ... <本地保存文件路径> +``` +导出指定文件/目录下面的所有文件的元数据信息,并保存到指定的本地文件里面。导出的文件元信息可以使用 import 命令(秒传文件功能)导入到网盘中。 + +### 例子 +``` +导出 /我的资源 整个目录 元数据到文件 /Users/tickstep/Downloads/export_files.txt +aliyunpan export /我的资源 /Users/tickstep/Downloads/export_files.txt + +导出 网盘 整个目录 元数据到文件 /Users/tickstep/Downloads/export_files.txt +aliyunpan export / /Users/tickstep/Downloads/export_files.txt +``` + +## 导入文件 +``` +aliyunpan export <本地元数据文件路径> +``` +导入文件中记录的元数据文件到网盘。保存到网盘的文件会使用文件元数据记录的路径位置,如果没有指定云盘目录(saveto)则默认导入到目录 aliyunpan 中。 +导入的文件可以使用 export 命令获得。 + +导入文件每一行是一个文件元数据,样例如下: +``` +aliyunpan://file.dmg|752FCCBFB2436A6FFCA3B287831D4FAA5654B07E|7005440| +``` + +### 例子 +``` +导入文件 /Users/tickstep/Downloads/export_files.txt 存储的所有文件元数据项 +aliyunpan import /Users/tickstep/Downloads/export_files.txt + +导入文件 /Users/tickstep/Downloads/export_files.txt 存储的所有文件元数据项并保存到目录 /my2020 中 +aliyunpan import -saveto=/my2020 /Users/tickstep/Downloads/export_files.txt + +导入文件 /Users/tickstep/Downloads/export_files.txt 存储的所有文件元数据项并保存到网盘根目录 / 中 +aliyunpan import -saveto=/ /Users/tickstep/Downloads/export_files.txt +``` + +## 分享文件/目录 +``` +aliyunpan share +``` + +### 设置分享文件/目录 +阿里目前之支持少数文件类型的分享,不支持的文件分享会提示分享失败 +``` +aliyunpan share set <文件/目录1> <文件/目录2> ... +aliyunpan share s <文件/目录1> <文件/目录2> ... +``` + +### 列出已分享文件/目录 +``` +aliyunpan share list +aliyunpan share l +``` + +### 取消分享文件/目录 +``` +aliyunpan share cancel ... +aliyunpan share c ... +``` +目前只支持通过分享id (shareid) 来取消分享. + + +### 分享秒传链接 +秒传链接支持所有类型的文件分享,可以突破阿里的分享限制。得到的链接可以使用import或者rapidupload命令保存到自己网盘中。 +秒传链接只支持文件分享,不支持文件夹。如果指定文件夹会创建文件夹下所有文件的秒传链接。 +``` +aliyunpan share mc <文件/目录1> <文件/目录2> ... + +例子 +# 创建文件 1.mp4 的秒传链接 +aliyunpan share mc 1.mp4 + +# 创建文件 1.mp4 的秒传链接,但链接隐藏相对路径 +aliyunpan share mc -hp 1.mp4 + +# 创建文件夹 share_folder 下面所有文件的秒传链接 +aliyunpan share mc share_folder/ +``` + +## 同步备份功能 +同步备份功能,支持备份本地文件到云盘,备份云盘文件到本地,双向同步备份三种模式。支持JavaScript插件对备份文件进行过滤。 +指定本地目录和对应的一个网盘目录,以备份文件。网盘目录必须和本地目录独占使用,不要用作其他用途,不然备份可能会有问题。 + +备份功能支持以下三种模式: +1. 备份本地文件,即上传本地文件到网盘,始终保持本地文件有一个完整的备份在网盘 +2. 备份云盘文件,即下载网盘文件到本地,始终保持网盘的文件有一个完整的备份在本地 +3. 双向备份,保持网盘文件和本地文件严格一致 + +备份功能一般用于NAS等系统,进行文件备份。比如备份照片,就可以使用这个功能定期备份照片到云盘,十分好用。 + +### 常用命令说明 +``` +查看同步备份功能说明 +aliyunpan sync + +查看如何配置和启动同步备份功能 +aliyunpan sync start -h + +使用命令行配置启动同步备份服务,将本地目录 D:\tickstep\Documents\设计文档 中的文件备份上传到云盘目录 /sync_drive/我的文档 +aliyunpan sync start -ldir "D:\tickstep\Documents\设计文档" -pdir "/sync_drive/我的文档" -mode "upload" + +使用命令行配置启动同步备份服务,将云盘目录 /sync_drive/我的文档 中的文件备份下载到本地目录 D:\tickstep\Documents\设计文档 +aliyunpan sync start -ldir "D:\tickstep\Documents\设计文档" -pdir "/sync_drive/我的文档" -mode "download" + +使用命令行配置启动同步备份服务,将本地目录 D:\tickstep\Documents\设计文档 中的文件备份到云盘目录 /sync_drive/我的文档 +同时配置下载并发为2,上传并发为1,下载分片大小为256KB,上传分片大小为1MB +aliyunpan sync start -ldir "D:\tickstep\Documents\设计文档" -pdir "/sync_drive/我的文档" -mode "upload" -dp 2 -up 1 -dbs 256 -ubs 1024 + +使用配置文件启动同步备份服务,使用配置文件可以支持同时启动多个备份任务。配置文件必须存在,否则启动失败。 +aliyunpan sync start + +使用配置文件启动同步备份服务,并配置下载并发为2,上传并发为1,下载分片大小为256KB,上传分片大小为1MB +aliyunpan sync start -dp 2 -up 1 -dbs 256 -ubs 1024 +``` + +### 备份配置文件说明 +如果你只有一个文件夹进行备份建议直接使用命令行配置启动即可。如果需要同时启动多个备份任务,则可以使用备份配置文件启动同步备份任务。 +配置文件如下所示,如果你有通过环境变量ALIYUNPAN_CONFIG_DIR设置配置目录,则需要将sync_drive文件夹拷贝到配置的目录中才可以生效。 +``` +配置文件需要保存在:(配置目录)/sync_drive/sync_drive_config.json,样例如下: + +{ + "configVer": "1.0", + "syncTaskList": [ + { + "name": "设计文档备份", + "localFolderPath": "D:/tickstep/Documents/设计文档", + "panFolderPath": "/备份盘/我的文档", + "mode": "upload" + }, + { + "name": "手机图片备份", + "localFolderPath": "D:/tickstep/Photos/手机图片", + "panFolderPath": "/备份盘/手机图片", + "mode": "upload" + } + ] +} + +相关字段说明如下: +name - 任务名称 +localFolderPath - 本地目录 +panFolderPath - 网盘目录 +mode - 模式,支持三种: upload(备份本地文件到云盘),download(备份云盘文件到本地),sync(双向同步备份) +``` + +### 命令行启动 +需要先进行登录。然后使用以下命令运行即可,该命令是阻塞的不会退出。 + +``` +使用命令行配置启动同步备份服务,将本地目录 /tickstep/Documents/设计文档 中的文件备份上传到云盘目录 /备份盘/我的文档 +./aliyunpan sync start -ldir "/tickstep/Documents/设计文档" -pdir "/备份盘/我的文档" -mode "upload" + +参数说明 +ldir:本地目录 +pdir:云盘目录 +mode:备份模式,支持:upload(备份本地文件到云盘),download(备份云盘文件到本地),sync(双向同步备份) + +-------------------------------------------------------------- +正常会有以下的输出: + +启动同步备份进程 +备份配置文件:(使用命令行配置) +链接类型:默认链接 +下载并发:2 +上传并发:2 +下载分片大小:1.00MB +上传分片大小:10.00MB + +启动同步任务 +任务: 设计文档(de3d6b69a607497b73624bcca0845f19) +同步模式: 备份本地文件(只上传) +本地目录: /tickstep/Documents/设计文档 +云盘目录: /备份盘/我的文档 +``` + +### Linux后台启动 +建议结合nohup进行启动。 + +sync.sh脚本,内容如下 +``` +# 请更改成你自己的目录 +cd /path/to/aliyunpan/folder + +chmod +x ./aliyunpan + +# 指定refresh token用于登录 +./aliyunpan login -RefreshToken=9078907....adg9087 + +# 上传下载链接类型:1-默认 2-阿里ECS环境 +./aliyunpan config set -transfer_url_type 1 + +# 指定配置参数并进行启动 +# 支持的模式:upload(备份本地文件到云盘),download(备份云盘文件到本地),sync(双向同步备份) +./aliyunpan sync start -ldir "/tickstep/Documents/设计文档" -pdir "/备份盘/我的文档" -mode "upload" +``` + +增加脚本执行权限 +``` +$ chmod +x sync.sh +``` + +然后启动该脚本进行后台运行 +``` +$ nohup ./sync.sh >/dev/null 2>&1 & +``` + +### Windows后台启动 +需要结合 [WinSW](https://github.com/winsw/winsw) 进行后台启动,请前往官网自行下载: https://github.com/winsw/winsw + +步骤如下: +1. 配置好备份任务:(配置目录)\sync_drive\sync_drive_config.json +2. 下载winsw.exe并更名为alisync.exe +3. 新增一个alisync.xml文件,内容如下: +```xml + + alisync + alisync + aliyunpan-sync 后台备份服务。 + + aliyunpan.exe + sync start + + +``` +4. 将alisync.exe和alisync.xml存放在你PC上aliyunpan.exe工具所在目录,例如: + ![](../assets/images/win10-alisync-service.png) +5. CMD命令行启动程序 +``` +# 安装服务(只需要第一次安装,后面不用再安装) +D:\Program Files\aliyunpan>alisync install + +# 启动服务 +D:\Program Files\aliyunpan>alisync start +2022-06-21 13:39:05,795 INFO - Starting service 'alisync (alisync)'... +2022-06-21 13:39:06,361 INFO - Service 'alisync (alisync)' started successfully. + +# 查看服务状态 +D:\Program Files\aliyunpan>alisync status +Started + +# 停止服务 +D:\Program Files\aliyunpan>alisync stop +2022-06-21 13:42:32,201 INFO - Stopping service 'alisync (alisync)'... +2022-06-21 13:42:32,211 INFO - Service 'alisync (alisync)' stopped successfully. +``` +效果截图如下 +![](../assets/images/win10-alisync-service-bg.png) + +### Docker运行 +详情文档请参考dockerhub网址:[tickstep/aliyunpan-sync](https://hub.docker.com/r/tickstep/aliyunpan-sync) + +1. 直接运行 +``` +docker run -d --name=aliyunpan-sync --restart=always -v ":/home/app/data" -e TZ="Asia/Shanghai" -e ALIYUNPAN_REFRESH_TOKEN="" -e ALIYUNPAN_PAN_DIR="" -e ALIYUNPAN_SYNC_MODE="upload" tickstep/aliyunpan-sync + +:本地目录绝对路径,例如:/tickstep/Documents/设计文档 +ALIYUNPAN_PAN_DIR:云盘目录 +ALIYUNPAN_REFRESH_TOKEN:RefreshToken +ALIYUNPAN_SYNC_MODE:备份模式,支持三种: upload(备份本地文件到云盘),download(备份云盘文件到本地),sync(双向同步备份) +``` + +2. docker-compose运行 + docker-compose.yml 文件如下所示,为了方便说明增加了相关的注释,部署的时候可以去掉注释。 + +``` +version: '3' +services: + sync: + image: tickstep/aliyunpan-sync: + container_name: aliyunpan-sync + restart: always + volumes: + # 指定本地备份目录绝对路径:/tickstep/Documents/设计文档 + - /tickstep/Documents/设计文档:/home/app/data:rw + # (可选)可以指定JS插件sync_handler.js用于过滤文件,详见下面的插件说明 + #- ./plugin/js/sync_handler.js:/home/app/config/plugin/js/sync_handler.js + # (推荐)挂载sync_drive同步数据库到本地 + #- ./sync_drive:/home/app/config/sync_drive + environment: + - TZ=Asia/Shanghai + # refresh token + - ALIYUNPAN_REFRESH_TOKEN=41804446a...bf7f069cab2 + # 上传下载链接类型:1-默认 2-阿里ECS环境 + - ALIYUNPAN_TRANSFER_URL_TYPE=1 + # 下载文件并发数 + - ALIYUNPAN_DOWNLOAD_PARALLEL=2 + # 上传文件并发数 + - ALIYUNPAN_UPLOAD_PARALLEL=2 + # 下载数据块大小,单位为KB,默认为10240KB,建议范围1024KB~10240KB + - ALIYUNPAN_DOWNLOAD_BLOCK_SIZE=1024 + # 上传数据块大小,单位为KB,默认为10240KB,建议范围1024KB~10240KB + - ALIYUNPAN_UPLOAD_BLOCK_SIZE=10240 + # 指定网盘文件夹作为备份目录,不要指定根目录 + - ALIYUNPAN_PAN_DIR=/备份盘/我的文档 + # 备份模式:upload(备份本地文件到云盘), download(备份云盘文件到本地), sync(双向同步备份) + - ALIYUNPAN_SYNC_MODE=upload +``` + +3. sync_handler.js插件说明 + 可以使用JS插件过滤备份的文件。 +```javascript +// ========================================================================================== +// aliyunpan JS插件回调处理函数 +// 支持 JavaScript ECMAScript 5.1 语言规范 +// +// 更多内容请查看官方文档:https://github.com/tickstep/aliyunpan +// ========================================================================================== + +// ------------------------------------------------------------------------------------------ +// 函数说明:同步备份-扫描本地文件前的回调函数 +// +// 参数说明 +// context - 当前调用的上下文信息 +// { +// "appName": "aliyunpan", +// "version": "v0.1.3", +// "userId": "11001d48564f43b3bc5662874f04bb11", +// "nickname": "tickstep", +// "fileDriveId": "19519111", +// "albumDriveId": "29519122" +// } +// appName - 应用名称,当前固定为aliyunpan +// version - 版本号 +// userId - 当前登录用户的ID +// nickname - 用户昵称 +// fileDriveId - 用户文件网盘ID +// albumDriveId - 用户相册网盘ID +// +// params - 扫描本地文件前参数 +// { +// "localFilePath": "D:\\Program Files\\aliyunpan\\Downloads\\token.bat", +// "localFileName": "token.bat", +// "localFileSize": 125330, +// "localFileType": "file", +// "localFileUpdatedAt": "2022-04-14 07:05:12", +// "driveId": "19519221" +// } +// localFilePath - 本地文件绝对完整路径 +// localFileName - 本地文件名 +// localFileSize - 本地文件大小,单位B +// localFileType - 本地文件类型,file-文件,folder-文件夹 +// localFileUpdatedAt - 文件修改时间 +// driveId - 备份的目标网盘ID +// +// 返回值说明 +// { +// "syncScanLocalApproved": "yes" +// } +// syncScanLocalApproved - 该文件是否确认扫描,yes-允许扫描,no-禁止扫描。 +// 禁止扫描的文件不会执行后续的动作,例如上传,下载。 +// ------------------------------------------------------------------------------------------ +function syncScanLocalFilePrepareCallback(context, params) { + console.log(params); + var result = { + "syncScanLocalApproved": "yes" + }; + + // 禁止.开头文件上传 + if (params["localFileName"].indexOf(".") == 0) { + result["syncScanLocalApproved"] = "no"; + } + + // 禁止~$开头文件上传(office暂存临时文件) + if (params["localFileName"].indexOf("~$") == 0) { + result["syncScanLocalApproved"] = "no"; + } + + // 禁止.txt文件上传(正则表达式方式) + if (params["localFileName"].search(/.txt$/i) >= 0) { + result["syncScanLocalApproved"] = "no"; + } + + // 禁止password.key文件上传 + if (params["localFileName"] == "password.key") { + result["syncScanLocalApproved"] = "no"; + } + + // 禁止@eadir文件上传 + if (params["localFileName"] == "@eadir") { + result["syncScanLocalApproved"] = "no"; + } + return result; +} + + +// ------------------------------------------------------------------------------------------ +// 函数说明:同步备份-扫描云盘文件前的回调函数 +// +// 参数说明 +// context - 当前调用的上下文信息 +// { +// "appName": "aliyunpan", +// "version": "v0.1.3", +// "userId": "11001d48564f43b3bc5662874f04bb11", +// "nickname": "tickstep", +// "fileDriveId": "19519111", +// "albumDriveId": "29519122" +// } +// appName - 应用名称,当前固定为aliyunpan +// version - 版本号 +// userId - 当前登录用户的ID +// nickname - 用户昵称 +// fileDriveId - 用户文件网盘ID +// albumDriveId - 用户相册网盘ID +// +// params - 扫描云盘文件前参数 +// { +// "driveId": "19519221", +// "driveFileName": "token.bat", +// "driveFilePath": "/aliyunpan/Downloads/token.bat", +// "driveFileSha1": "08FBE28A5B8791A2F50225E2EC5CEEC3C7955A11", +// "driveFileSize": 125330, +// "driveFileType": "file", +// "driveFileUpdatedAt": "2022-04-14 07:05:12" +// } +// driveId - 网盘ID +// driveFileName - 网盘文件名 +// driveFilePath - 网盘文件绝对完整路径 +// driveFileSize - 网盘文件大小,单位B +// driveFileSha1 - 网盘文件SHA1 +// driveFileType - 网盘文件类型,file-文件,folder-文件夹 +// driveFileUpdatedAt - 网盘文件修改时间 +// +// 返回值说明 +// { +// "syncScanPanApproved": "yes" +// } +// syncScanPanApproved - 该文件是否确认扫描,yes-允许扫描,no-禁止扫描。 +// 禁止扫描的文件不会执行后续的动作,例如上传,下载。 +// ------------------------------------------------------------------------------------------ +function syncScanPanFilePrepareCallback(context, params) { + console.log(params); + + var result = { + "syncScanPanApproved": "yes" + }; + + // 禁止.开头文件下载 + if (params["driveFileName"].indexOf(".") == 0) { + result["syncScanPanApproved"] = "no"; + } + + // 禁止~$开头文件下载(office暂存临时文件) + if (params["driveFileName"].indexOf("~$") == 0) { + result["syncScanPanApproved"] = "no"; + } + + // 禁止.txt文件下载(正则表达式方式) + // if (params["driveFileName"].search(/.txt$/i) >= 0) { + // result["syncScanPanApproved"] = "no"; + // } + + return result; +} +``` + +## webdav文件服务 +本文命令可以让阿里云盘变身为webdav协议的文件服务器。这样你可以把阿里云盘挂载为Windows、Linux、Mac系统的磁盘,可以通过NAS系统做文件管理或文件同步等等。 +当把阿里云盘作为webdav文件服务器进行使用的时候,上传文件是不支持秒传的,所以当你挂载为网络磁盘使用的时候,不建议在webdav挂载目录中上传、下载过大的文件,不然体验会非常差。 +建议作为文档,图片等小文件的同步网盘。 +效果图如下所示: +![](../assets/images/webdav-screenshot.png) + +### 常用命令说明 +``` +查看webdav说明 +aliyunpan webdav + +查看webdav如何启动说明 +aliyunpan webdav start -h + +使用默认配置启动webdav服务。 +aliyunpan webdav start + +启动webdav服务,并配置IP为127.0.0.1,端口为23077,登录用户名为admin,登录密码为admin123,文件网盘目录 /webdav_folder 作为服务的根目录 +aliyunpan webdav start -ip "127.0.0.1" -port 23077 -webdav_user "admin" -webdav_password "admin123" -pan_drive "File" -pan_dir_path "/webdav_folder" + +正常启动后会打印出webdav链接参数,然后使用支持webdav的客户端填入下面对应的参数进行链接即可 +---------------------------------------- +webdav网盘信息: +链接:http://localhost:23077 +用户名:admin +密码:admin123 +网盘服务类型:文件 +网盘服务目录:/webdav_folder +---------------------------------------- +``` + +### 命令行启动 +需要先进行登录。然后使用以下命令运行即可,该命令是阻塞的不会退出,除非停止webdav服务。 + +``` +./aliyunpan webdav start -port 23077 -webdav_user "admin" -webdav_password "admin123" -pan_dir_path "/webdav_folder" + +参数说明 +port:绑定端口 +webdav_user: webdav客户端登录用户名 +webdav_password: webdav客户端登录密码 +pan_dir_path:指定webdav使用那个阿里云盘目录作为服务根目录 +``` + +### Linux后台启动 +建议结合nohup进行启动。 + +先创建webdav.sh脚本,内容如下 +``` +# 请更改成你自己的目录 +cd /path/to/aliyunpan/folder + +chmod +x ./aliyunpan + +# 指定refresh token用于登录 +./aliyunpan login -RefreshToken=9078907....adg9087 + +# 上传下载链接类型:1-默认 2-阿里ECS环境 +./aliyunpan config set -transfer_url_type 1 + +# 指定webdav启动参数并进行启动 +./aliyunpan webdav start -ip "0.0.0.0" -port 23077 -webdav_user "admin" -webdav_password "admin" -pan_dir_path "/" -bs 1024 +``` + +增加脚本执行权限 +``` +$ chmod +x webdav.sh +``` + +然后启动该脚本进行后台运行 +``` +$ nohup ./webdav.sh >/dev/null 2>&1 & +``` + +### Docker运行 +详情文档请参考dockerhub网址:[tickstep/aliyunpan-webdav](https://hub.docker.com/r/tickstep/aliyunpan-webdav) + +1. 直接运行 +``` +docker run -d --name=aliyunpan-webdav --restart=always -p 23077:23077 -e TZ="Asia/Shanghai" -e ALIYUNPAN_REFRESH_TOKEN="" -e ALIYUNPAN_AUTH_USER="admin" -e ALIYUNPAN_AUTH_PASSWORD="admin" -e ALIYUNPAN_PAN_DRIVE="File" -e ALIYUNPAN_PAN_DIR="/" tickstep/aliyunpan-webdav + +# ALIYUNPAN_REFRESH_TOKEN RefreshToken +# ALIYUNPAN_AUTH_USER webdav登录用户名 +# ALIYUNPAN_AUTH_PASSWORD webdav登录密码 +# ALIYUNPAN_PAN_DRIVE 网盘类型,可选: File-文件 Album-相册 +# ALIYUNPAN_PAN_DIR 网盘文件夹的webdav服务根目录 +``` + +2. docker-compose运行 + docker-compose.yml 文件如下所示,为了方便说明增加了相关的注释,部署的时候可以去掉注释。 +``` +version: '3' +services: + webdav: + image: tickstep/aliyunpan-webdav + container_name: aliyunpan-webdav + restart: always + ports: + - 23077:23077 + environment: + - TZ=Asia/Shanghai + # refresh token用于登录 + - ALIYUNPAN_REFRESH_TOKEN=b9123...13e66a1 + # webdav 登录用户名 + - ALIYUNPAN_AUTH_USER=admin + # webdav 登录密码 + - ALIYUNPAN_AUTH_PASSWORD=admin + # 指定网盘类型为文件,可选: File-文件 Album-相册 + - ALIYUNPAN_PAN_DRIVE=File + # 指定网盘文件夹作为webdav服务根目录 + - ALIYUNPAN_PAN_DIR=/ + # 上传下载链接类型:1-默认 2-阿里ECS环境 + - ALIYUNPAN_TRANSFER_URL_TYPE=1 + # 上传数据块大小,单位为KB,默认为10240KB,建议范围1024KB~10240KB + - ALIYUNPAN_BLOCK_SIZE=10240 +``` + +### HTTPS配置 +建议使用nginx进行https的配置。样例如下: +``` +server { + listen 443; + server_name your.host.com; + ssl on; + root html; + index index.html index.htm; + ssl_certificate /path/to/your/file.pem; + ssl_certificate_key /path/to/your/file.key; + + ssl_session_timeout 5m; + ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4; + ssl_protocols TLSv1 TLSv1.1 TLSv1.2; + ssl_prefer_server_ciphers on; + + # webdav server + location /{ + root html; + proxy_pass http://127.0.0.1:23077; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header REMOTE-HOST $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header Host $http_host; + proxy_redirect off; + } + } +``` + +## JavaScript插件 +支持javascript插件,你可以按照自己的需要定制上传/下载中关键步骤的行为,最大程度满足自己的个性化需求。 +例如: +1.排除某个特定敏感文件的上传 +2.上传文件进行改名,但是本地文件不做更改 +3.上传完成文件,删除本地文件 +4.上传的文件路径进行更改,但是本地的文件保持不变 +5.上传文件成功后,通过HTTP通知其他服务 +6.排除某些网盘文件的下载 +7.下载的文件进行改名,但是网盘的文件保持不变 +8.下载的文件路径进行更改,但是网盘的文件保持不变 +9.下载文件完成后,通过HTTP通知其他服务 +10.同步备份功能,支持过滤本地文件,或者过滤云盘文件。定制上传或者下载需要同步的文件 + +### 如何使用 +JS插件的样本文件默认存放在程序所在的plugin/js文件夹下,分为下载(download_handler.js.sample)、上传(upload_handler.js.sample)、同步备份(sync_handler.js.sample)插件。 + +建议拷贝一份并将后缀名更改为.js,例如:upload_handler.js,不然插件不会生效。 +你必须具备一定的JS语言基础,然后按照里面的样例根据自己所需进行改动即可。 +如果你有通过环境变量ALIYUNPAN_CONFIG_DIR设置配置目录,则需要将plugin文件夹拷贝到配置的目录中才可以生效。 + +### JS中内置的函数 +目前只开放了如下函数,你可以在你的js脚本中直接调用 +1.console.log() +打印日志 +``` +console.log("hello world"); +``` + +2.PluginUtil.Http.get() +发起HTTP的get请求 +``` + var header = { + "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/100.0.4896.88 Safari/537.36", + "Content-Type": "application/json", + "Accept": "application/json" + }; + try { + var r = PluginUtil.Http.get(header, "https://625f528c53a42eaa07f37e13.mockapi.io/files/1"); + console.log(r); + } catch (e) { + if (e !== "Error") { + throw e; + } + } +``` + +3.PluginUtil.Http.post() +发起HTTP的post请求 +``` + var header = { + "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/100.0.4896.88 Safari/537.36", + "Content-Type": "application/json", + "Accept": "application/json" + }; + try { + var reqDataStr = JSON.stringify({ + "id": "1", + "localFilePath": "/usr/local/src/borders_burundi_producer.gram.aab", + "localFileSize": 1111, + "uploadApproved": false + }); + var r = PluginUtil.Http.post(header, "https://625f528c53a42eaa07f37e13.mockapi.io/files", reqDataStr); + console.log(r); + } catch (e) { + if (e !== "Error") { + throw e; + } + } +``` + +4.PluginUtil.LocalFS.deleteFile() +删除本地指定文件,不支持文件夹 +``` +PluginUtil.LocalFS.deleteFile(params["localFilePath"]); +``` + +## 显示和修改程序配置项 +``` +# 显示配置 +aliyunpan config + +# 设置配置 +aliyunpan config set +``` + + +### 例子 +``` +# 显示所有可以设置的值 +aliyunpan config -h +aliyunpan config set -h + +# 设置下载文件的储存目录 +aliyunpan config set -savedir D:/Downloads + +# 设置下载最大并发量为 15 +aliyunpan config set -max_download_parallel 15 + +# 组合设置 +aliyunpan config set -max_download_parallel 15 -savedir D:/Downloads + +# 设置使用阿里云内部URL链接,专供阿里云ECS环境使用 +# 开启内部URL链接可以使用阿里云ECS私网带宽流量,而不用使用宝贵的公网带宽流量,如果你在阿里ECS环境中使用本工具,建议开启 +aliyunpan config set -transfer_url_type 2 +``` + +# 常见问题Q&A +## 1 如何获取RefreshToken +需要通过浏览器获取refresh_token。这里以Chrome浏览器为例,其他浏览器类似。 +打开 [阿里云盘网页](https://www.aliyundrive.com/drive) 并进行登录,然后F12按键打开浏览器调试菜单,按照下面步骤进行 +![](../assets/images/how-to-get-refresh-token.png) + +或者直接在控制台输入以下命令获取 +``` +JSON.parse(localStorage.getItem("token")).refresh_token +``` +![](../assets/images/how-to-get-refresh-token-cmd.png) + +## 2 如何开启Debug调试日志 +当需要定位问题,或者提交issue的时候抓取log,则需要开启debug日志。步骤如下: + +### 第一步 +Linux&MacOS +命令行运行 +``` +export ALIYUNPAN_VERBOSE=1 +``` + +Windows +不同版本会有些许不一样,请自行查询具体方法 +设置示意图如下: +![](../assets/images/win10-env-debug-config.png) + +### 第二步 +打开aliyunpan命令行程序,任何云盘命令都有类似如下日志输出 +![](../assets/images/debug-log-screenshot.png) + +## 3 解决 missing Location in call to Date 问题 +在使用webdav文件服务的过程中可能会出现该问题。 +原因是golang中的time.LoadLocation()依赖于 IANA Time Zone Database,一般linux系统都带了,但是有部分系统没有带有这个数据文件则出现该问题。 +解决方法: +1. 下载文件 ./assets/binary/tzdata.zip 文件并保存到系统中,记下保存的文件路径 +2. 设置环境变量 ZONEINFO +``` +export ZONEINFO=/path/to/tzdata.zip +``` +然后启动aliyunpan服务即可。 \ No newline at end of file