基于go的轻量级文件服务器,自建云盘系列——FileManager(基于Go的轻量级解决方案)...

文章目录[隐藏]

49c9da04ad1679b73ce308baca8055ef.png

一.介绍

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,其他看下图

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

948872289a4fa0552929ac7ebc497464.png

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

37103029f41f3f49bf5e2a1dc94a67ee.png

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

fa689556b9d47ed19dbcbd21686fdef1.png

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值