影片自由,丝滑流畅,Docker容器基于WebDav协议通过Alist挂载(百度网盘/阿里云盘)Python3.10接入

影片,自由,流畅,docker,容器,基于,webdav,协议,通过,alist,挂载,百度网,阿里,云盘,python3,接入 · 浏览次数 : 2163

小编点评

**登录Alist服务教程** **步骤一:安装WebDav库** ```python pip3 install webdavclient3 ``` **步骤二:创建WebDav服务器** 使用以下命令在本地启动WebDav服务器: ```bash docker run -d --restart=always -v /root/data/docker_data/alist:/opt/alist/data -p 5244:5244 --name=\"alist\" xhofe/alist:latest ``` **步骤三:获取WebDav服务器的IP地址** 使用以下命令获取WebDav服务器的IP地址: ```bash docker logs alist | grep IP | awk '{print $2;}' ``` **步骤四:设置WebDav服务器的账号和密码** 使用以下命令设置WebDav服务器的账号和密码: ```bash docker exec -i alist bash ``` 输入以下命令,然后按回车键: ```bash username:your_username password:your_password ``` **步骤五:创建目标目录** ```bash mkdir -p /path/to/your/target/directory ``` **步骤六:删除资源** ```bash rm -rf /path/to/your/target/directory/* ``` **步骤七:上传资源** ```bash cp -r /path/to/your/source/directory/* /path/to/your/target/directory ``` **步骤八:下载资源** ```bash wget -O /path/to/your/target/directory/file.ext /path/to/your/source/directory/file.ext ``` **步骤九:上传文件** ```bash put file.ext /path/to/your/target/directory ``` **步骤十:关闭WebDav服务器** ```bash docker stop alist ```

正文

使用过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/callback?code=288faa8f669a3d174ea9af0bd1d72ab5 进行授权操作,记录client_id、client_secret和refresh_token,分别将三个参数填入挂载的表单中,然后挂载目录填入根目录:/,注意表单中最好把web代理选项勾选。

随后进入Alist服务首页:http://localhost:5244,就可以在线播放百度云内存储的资源:

非常方便。

挂载阿里云盘

截止到本文发布的2-14号,阿里云盘目前挂载过程中会出现设备id的bug,但是挂载阿里云盘分享的网盘还是没问题的,由于阿里云盘操作基于客户端的token,所以必须先通过移动端登录页面来获取token:

https://passport.aliyundrive.com/mini_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,新时代的普罗米修斯,为我们带来了网盘自由的火种。

与影片自由,丝滑流畅,Docker容器基于WebDav协议通过Alist挂载(百度网盘/阿里云盘)Python3.10接入相似的内容:

影片自由,丝滑流畅,Docker容器基于WebDav协议通过Alist挂载(百度网盘/阿里云盘)Python3.10接入

使用过NAS(Network Attached Storage)的朋友都知道,它可以通过局域网将本地硬盘转换为局域网内的“网盘”,简单理解就是搭建自己的“私有云”,但是硬件和网络成本都太高了,有点可望而不可及的意思。Alist开源库则可以满足我们,它能将公共网盘反过来变成一种联网的本地硬盘,使用We

FTP主动模式和被动模式(2)- 防火墙对FTP的影响 ASPF

防火墙对FTP的影响 ASPF 多通道协议 应用层程序有些使用的是单通道协议,有些使用的是多通道协议。 单通道协议 例如http协议,整个协议交互过程中,服务端和客户端只建立一个连接,并且服务端固定使用一个端口,例如80端口,这种一般为单通道协议; 防火墙一般都需要配置精细的安全策略对数据进行防护,

声音好听,颜值能打,基于PaddleGAN给人工智能AI语音模型配上动态画面(Python3.10)

借助So-vits我们可以自己训练五花八门的音色模型,然后复刻想要欣赏的任意歌曲,实现点歌自由,但有时候却又总觉得少了点什么,没错,缺少了画面,只闻其声,却不见其人,本次我们让AI川普的歌声和他伟岸的形象同时出现,基于PaddleGAN构建“靓声靓影”的“懂王”。 PaddlePaddle是百度开源

ENVI自动地理配准:GCP地面控制点的自动产生

本文介绍基于ENVI软件,利用“Image Registration Workflow”工具实现栅格遥感影像自动寻找地面控制点从而实现地理配准的方法~

固定型思维 VS 成长型思维

回顾进入职场工作以来,对比曾经的学生时代,如果让我讲一个对自己影响最大的改变,那就是思维模式的一个转变。 具体来说,就是从一个典型的固定型思维转变成一个具备有成长型思维的人。 当然,我不敢妄称自己已经是全面的成长型思维,但我的的确确已经意识到成长型思维的好处。 最起码,我可以不再像曾经学生时代的那个

go多版本管理

在日常开发工作过程中,很多时候我们都需要在自己的机器上安装多个go版本,像是go1.16引入的embed,go1.18引入了泛型;又或是自己本地使用的是最新版,但公司的项目中使用的go1.14、go1.13甚至是更早的版本。 那么有没有既不影响我们自己的本地环境,又能兼顾历史项目的办法呢?答案当然是

[转帖]分析核亲和性对高吞吐量的流的影响

https://www.cnblogs.com/charlieroro/p/14182908.html 本文翻译自Analysis of the Effect of Core Affinity on High-Throughput Flows 简介 网络吞吐量正在朝更高的数据传输率发展,与此同时,终

记录一次排查解决服务器卡死的过程

前言 自己个人兴趣爱好,线上有一个阿里云服务器,处理数据用的,会频繁IO和分析数据。隔一段时间就会卡死(大概2个月),重启就OK。本来没当一回事,直到后来影响到赚取money了才引起重视。服务的启动脚本如下: nohup java -Xms512m -Xmx1024m -jar xxx.jar &

Python核对遥感影像批量下载情况的方法

本文介绍批量下载遥感影像时,利用Python实现已下载影像文件的核对,并自动生成未下载影像的下载链接列表的方法~

DevOps 在未来将如何演进?丨行业观察

自2007年 DevOps 这一概念推出以来,越来越多企业开始将开发和运维团队结合在一起,以加快部署速度,提高软件开发生命周期的效率和协作。但是,诸多因素都会对 DevOps 是否成功产生影响,例如组织规模、文化和实施计划等。 随着系统愈发复杂,企业正在寻找新的方法来减轻开发人员的负担,同时加速软件