共计 5360 个字符,预计需要花费 14 分钟才能阅读完成。
应用过 NAS(Network Attached Storage)的敌人都晓得,它能够通过局域网将本地硬盘转换为局域网内的“网盘”,简略了解就是搭建本人的“公有云”,然而硬件和网络老本都太高了,有点可望而不可及的意思。Alist 开源库则能够满足咱们,它能将公共网盘反过来变成一种联网的本地硬盘,应用 Web 页面来对立挂载和治理,网盘类型蕴含但不限于:百度网盘、阿里云盘、迅雷网盘等等。
Alist 挂载网盘的另外一个益处是能够基于 WebDav 协定间接播放网盘资源,尽管说网盘也反对在线播放性能,然而代价就是得充会员,没错,这合乎逻辑,网盘主机厂也得盈利,但 Alist 技术能够帮忙咱们曲线救国,节俭一笔开销。
此外,应用 WebDAV 的精华在于 WebDAV 能够被挂载为一个本地 (服务器) 磁盘,正因为 WebDAV 能够被映射为一个本地目录,所以只须要调用本地播放器或者本地搭载的浏览器播放器进行播放。无论是 mkv、wmv 或是 h.265 编码方案,通过一个古代的本地播放器都能完满的播放,不存在须要转码的状况,所以,应用 WebDAV 协定,服务器的累赘只有传输数据这一个工作。
Docker 部署 Alist
Alist 软件能够通过多种形式进行装置和部署,但最不便的,还是通过 Docker,次要是因为因为各大网盘主机厂的网盘版本更新频率很快,所以 Alist 的版本也会随之频繁更新,而 Docker 的操作最简略快捷,只须要简略的命令就能够实现部署,更适宜这种频繁更新的状况。
对于 Docker 请移玉步至一寸宕机一寸血,十万容器十万兵 |Win10/Mac 零碎下基于 Kubernetes(k8s)搭建 Gunicorn+Flask 高可用 Web 集群,这里不作过多赘述。
首先在终端执行命令:
docker run -d --restart=always -v /etc/alist:/opt/alist/data -p 5244:5244 -e PUID=0 -e PGID=0 -e UMASK=022 --name="alist" xhofe/alist:latest
该命令会在后盾生成一个 Alist 容器,服务运行在零碎的 5244 端口,如果是首次运行,会拉取最新的 Alist 镜像:
➜ interview git:(main) docker run -d --restart=always -v /etc/alist:/opt/alist/data -p 5244:5244 -e PUID=0 -e PGID=0 -e UMASK=022 --name="alist" xhofe/alist:latest
Unable to find image 'xhofe/alist:latest' locally
latest: Pulling from xhofe/alist
b1101342f8ad: Pull complete
d9f5c37d20f9: Pull complete
5f4a1655e3cc: Pull complete
c1e599f8ce92: Pull complete
d613bea8ea45: Pull complete
Digest: sha256:520e531ddaf5732c4944d5c35ad4dbb601e2fadae14b99a81e86ea3f7e065173
Status: Downloaded newer image for xhofe/alist:latest
7bf1c7f384526bd22aa078223d548ab0c16b79c245919e8a0cf7b439e79f34d6
随后执行命令:
docker ps
就能够看到正在运行的 Alist 服务容器:
➜ ~ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
7bf1c7f38452 xhofe/alist:latest "/entrypoint.sh" 3 hours ago Up 3 hours 0.0.0.0:5244->5244/tcp alist
➜ ~
Alist 服务平台基于前后端拆散的 Gin 和 React,所以平台治理页面须要用户名和明码能力登入,输出命令:
docker exec -it alist ./alist admin
该命令会进入容器并展现账号和明码:
INFO[2023-02-13 22:54:17] admin user's info:
username: admin
password: 8U5js3bH
记录下来,留神这是本地的服务,所以外网是无奈进行登录的。
至此,Alist 的本地部署就实现了,如果 Alist 发了新的版本,也能够通过上面的命令进行更新操作:
docker stop alist #进行 alist 容器
docker rm -f alist #删除 alist 容器,因为之前映射到了本地,所以数据不会被删除
cp -r /root/data/docker_data/alist /root/data/docker_data/alist.bak #可选,如果不释怀,能够备份一下数据
docker pull xhofe/alist:latest #拉取最新的 alist 镜像
docker run -d --restart=always -v /root/data/docker_data/alist:/opt/alist/data -p 5244:5244 --name="alist" xhofe/alist:latest #运行装置命令,留神 - v 挂载的门路与原来雷同
这里的区别就是通过挂载命令将 alist 的配置文件挂载到宿主机的 /root/data/docker\_data/alist 目录,不便降级后进行应用。
挂载百度网盘
部署好 Alist 服务后,拜访本地网址进行登录:http://localhost:5244/@manage
用户名和明码就是上文中 Docker 中返回的,登录胜利后,抉择左侧菜单中的存储,增加百度网盘:
百度云盘的操作齐全基于百度云的凋谢 API,只有给 Alist 受权操作接口的权限即可,进入网址:https://tool.nn.ci/baidu/call… 进行受权操作,记录 client\_id、client\_secret 和 refresh\_token,别离将三个参数填入挂载的表单中,而后挂载目录填入根目录:/,留神表单中最好把 web 代理选项勾选。
随后进入 Alist 服务首页:http://localhost:5244,就能够在线播放百度云内存储的资源:
十分不便。
挂载阿里云盘
截止到本文公布的 2 -14 号,阿里云盘目前挂载过程中会呈现设施 id 的 bug,然而挂载阿里云盘分享的网盘还是没问题的,因为阿里云盘操作基于客户端的 token,所以必须先通过挪动端登录页面来获取 token:
https://passport.aliyundrive….\_login.htm?lang=zh\_cn&appName=aliyun\_drive&appEntrance=web&styleType=auto&bizParams=¬LoadSsoView=false¬KeepLogin=false&isMobile=true&hidePhoneCode=true&rnd=0.9186864872885723
登录胜利后,通过抓包,获取后端 login.do 接口的返回值:
将 bizExt 的值复制进去,而后利用 Python 的 Base64 模块进行解码操作:
import base64
coded_string = '''Q5YACgA...'''
base64.b64decode(coded_string)
解码进去的 refreshToken 就是咱们须要的令牌:
"refreshToken":"sdfdsfsdfdsfb9fadd4f62ee4be968e"
随后在后盾将 token 和分享的 id 填入表单即可:
留神这里挂载门路不能填入根目录 /,因为之前咱们曾经挂载了百度网盘了,所以抉择一个子目录 share。
至此,阿里云盘分享就挂载好了,能够坐下来,犒劳本人了:
Python3.10 接入
除了在线播放,咱们还能够应用 Python3.10 间接通过 WebDav 协定操作 Alist 挂载的网盘,堪称是神乎其技了。
首先装置 WebDav 库:
pip3 install webdavclient3
随后编写 webdav.py 文件:
from webdav3.client import Client
options = {
'webdav_hostname': "http://localhost:5244/dav",
'webdav_login': "admin",
'webdav_password': "8U5js3bH"
}
client = Client(options)
client.verify = False # To not check SSL certificates (Default = True)
files1 = client.list()
print(files1)
这里的 webdav\_hostname 指的是方才用 docker 挂载的 webdav 服务门路,账号和明码是上文中 docker 返回的,不必放心外泄,因为是本地服务。
程序返回:
➜ gotest /opt/homebrew/bin/python3.10 "/Users/liuyue/wodfan/work/gotest/webdav.py"
['dav/', 'aliyunpan/', 'The.Last.of.Us.S01E03.1080p.WEB-DL.DDP5.1.Atmos.H.264-Q66.mkv', 'The.Last.of.Us.S01E05.1080p.WEB-DL.DDP5.1.Atmos.H.264-Q66.mkv', 'The.Last.of.Us.S01E04.1080p.WEB-DL.DDP5.1.Atmos.H.264-Q66.mkv', 'house.of.the.dragon.s01e08.1080p.web.h264-cakes.chs.eng.mp4', 'House.of.the.Dragon.S01E07.Driftmark.1080p.HMAX.WEB-DL.DDP5.1.Atmos.H.264-SMURF.chs.eng.mp4', 'House.of.the.Dragon.S01E06.The.Princess.and.the.Queen.720p.HMAX.WEB-DL.DDP5.1.H.264-NTb.chs.eng.mp4', 'House.of.the.Dragon.S01E05.We.Light.the.Way.1080p.HMAX.WEB-DL.DDP5.1.Atmos.H.264-SMURF.chs.eng.mp4', 'house.of.the.dragon.s01e04.720p.web.h264-cakes.chs.eng.mp4', 'house.of.the.dragon.s01e03.720p.web.h264-cakes.chs.eng.mp4', 'share/']
能够很不便的将挂在后的网盘文件目录进行返回。
除此之外,咱们也能够针对网盘资源进行增删改查的动静操作:
# Create directory
client.mkdir("dir1/dir2")
# Delete resource
client.clean("dir1/dir2")
# Copy resource
client.copy(remote_path_from="dir1/file1", remote_path_to="dir2/file1")
client.copy(remote_path_from="dir2", remote_path_to="dir3")
# Move resource
client.move(remote_path_from="dir1/file1", remote_path_to="dir2/file1")
client.move(remote_path_from="dir2", remote_path_to="dir3")
# Download a resource
client.download_sync(remote_path="dir1/file1", local_path="~/Downloads/file1")
client.download_sync(remote_path="dir1/dir2/", local_path="~/Downloads/dir2/")
# Upload resource
client.upload_sync(remote_path="dir1/file1", local_path="~/Documents/file1")
client.upload_sync(remote_path="dir1/dir2/", local_path="~/Documents/dir2/")
也就是说,只有 Alist 服务曾经挂载好网盘,咱们甚至不须要平台界面,只编写代码就能够对网盘资源予取予求。
结语
旧时王谢堂前燕,飞入寻常百姓家。只有一台联网的电脑,就能够实现本人的“公有云”,成本低到令人发指,Alist,新时代的普罗米修斯,为咱们带来了网盘自在的火种。