自建云盘系列——FileManager(基于Go的轻量级解决方案)

文章目录[隐藏]

一.介绍

Caddy,用Go写的一款相当优秀的Web服务器软件,它有不少很有特色的功能,国内目前来说用的不多,不过也逐渐有越来越多的人知道了,它有个特色的插件功能,其中一款插件是FileManager,可以类似H5ai一样提供一个美化的Index目录列表,但是功能更多,不仅能下载,还能上传。但是,我一直不知道这玩意竟然还有个独立版本,最近Loc有人提到,我才发现这个确实不错。所以另外介绍一下,当然,之后也可能顺便介绍一下FileRun,不过这个免费版我感觉功能限制的有点多,还是需要考虑下。

二.安装

简单到极致,看过我博客以前那些介绍用Go写的程序的文章的同学肯定对某个特点印象深刻,那就是安装贼鸡儿方便,特别是在官方提供现成的二进制文件的情况下,那就是下载--解压--done。FileManager秉承了这个优点,官方甚至不需要你自己下载对应的二进制文件,全是一键脚本,自动判断环境一步到位。

#Linux下, 提供curl和wget两种
curl -fsSL https://henriquedias.com/filemanager/get.sh | bash
 
wget -qO- https://henriquedias.com/filemanager/get.sh | bash
 
#Windows下, 需要以管理员运行powershell然后安装
iwr -useb https://henriquedias.com/filemanager/get.ps1 | iex

刺激不刺激,当然,你在安装了Caddy的情况下只需要打开http.filemanager插件就行了

此外,现在Docker这么火当然也少不了它

docker run \
 -v /path/to/sites/root:/srv \
 -v /path/to/config.json:/config.json \
 -v /path/to/database.db:/database.db \
 -p 80:80 \
 hacdias/filemanager

这个采用的是默认配置,如下

{
 "port": 80,
 "address": "",
 "database": "/etc/database.db",
 "scope": "/srv",
 "allowCommands": true,
 "allowEdit": true,
 "allowNew": true,
 "commands": []
}

你也可以把配置写到命令里

docker run \
 -v /path/to/sites/root:/srv \
 -v /path/to/database.db:/database.db \
 -p 80:80 \
 hacdias/filemanager
 --port 80
 --database /database.db
 --scope /srv
 --other-flag other-value

当然,有一点需要注意,那就是FileManager不支持SSL,所以如果需要SSL或者说想用HTTP/2加速,请换Caddy配合插件

下面介绍一下,FileManager的命令行参数以及配置文件

-a, --address 监听地址,默认为空,即为监听所有地址
-b, --baseurl 根地址,即为访问的入口地址
--prefixurl 前缀地址
-c, --config 指定配置文件
-d, --databaseis 数据库文件地址,默认为 “./filemanager.db”
-l, --log 显示错误日志记录器,可为 ‘stdout’, ‘stderr’ 或者是一个文件路径,默认为“stdout”
-p, --port 监听端口,默认为0,即为随机的可用端口
--staticgen 指定你是否需要启用静态网站生成器,可用 jekyll 以及 hugo
-v, --version 打印程序版本
--recaptcha-key ReCAPTCHA 站点 key ,配置后可在登陆处启用ReCAPTCHA
--recaptcha-secret ReCAPTCHA 站点 secret key ,配置后可在登陆处启用ReCAPTCHA
 
#下面的选项用于为新用户配置默认设置
--allow-commands 允许使用命令的默认值,默认为 true
--allow-edit 允许修改设置的默认值,默认为 true
--allow-new 允许新建设置的默认值,默认为 true
--allow-publish 允许发布功能,默认为 true
--view-mode 新用户默认查看视图,默认为 mosaic
--locale 新用户默认语言,可选 en, pt, jp, zh-cn, zh-tw (英语, 葡萄牙语, 日语, 简体中文, 繁体中文)
--commands 新用户可用命令,以空格分隔,默认为 “git svn hg”
--no-auth 禁用认证,启用这个选项会将权限设置为默认
-s, --scope 新用户的默认目录,默认为工作目录

下面举个栗子方便理解,在监听所有地址的80端口,数据库指定为/etc/fm.db,新用户默认可访问/data目录

filemanager --port 80 --database /etc/fm.db --scope /data

FileManager的配置文件支持多种写法,分别为JSON,YAML以及TOML

IN JSON:

{
 "port": 80,
 "noAuth": false,
 "baseURL": "/admin",
 "address": "127.0.0.1",
 "reCaptchaKey": "",
 "reCaptchaSecret": "",
 "database": "/path/to/database.db",
 "log": "stdout",
 "plugin": "",
 "scope": "/path/to/my/files",
 "allowCommands": true,
 "allowEdit": true,
 "allowNew": true,
 "commands": [
 "git",
 "svn"
 ]
}

In YAML:

port: 80
baseURL: /admin
noAuth: false
address: 127.0.0.1
reCaptchaKey: ''
reCaptchaSecret: ''
database: "/path/to/database.db"
log: stdout
plugin: ''
scope: "/path/to/my/files"
allowCommands: true
allowEdit: true
allowNew: true
commands:
- git
- svn

In TOML:

port = 80
baseURL = /admin
address = 127.0.0.1
noAuth = false
reCaptchaKey = ''
reCaptchaSecret = ''
database = "/path/to/database.db"
log = stdout
plugin = ''
scope = "/path/to/my/files"
allowCommands = true
allowEdit = true
allowNew = true
commands = ["git", "svn"]

建议看哪种顺眼选哪种,没必要纠结太多,反正也不是天天改

对了,默认用户名密码均为admin,其他看下图

这是登陆界面,所谓自建云盘嘛,虽然不一定有啥见不得人的东西,但是还是要上个锁的

在用户设置中,可以配置ACL规则以便多人使用的情况下防止搞事,当然自定义CSS这种东西提供了更多的可能性

支持命令操作,是不是很刺激,这样就能玩出更多花样了

声明:本文为原创,作者为 Svlik,转载时请保留本声明及附带文章链接:https://www.svlik.com/2436.html