fp-multiuser 是 frp 的一个服务端插件,用于支持多用户鉴权。
fp-multiuser 会以一个单独的进程运行,并接收 frps 发送过来的 HTTP 请求。
- 通过配置文件配置所有支持的用户名和 Token,只允许匹配的 frpc 客户端登录。
通过 Release 页面下载对应系统版本的二进制文件到本地。
需要 frp 版本 >= v0.31.0
-
创建
tokens
文件,内容为所有支持的用户名和 token。user1=123 user2=abc
每一个用户占一行,用户名和 token 之间以
=
号分隔。 -
运行 fp-multiuser,指定监听地址以及 token 存储文件路径。
./fp-multiuser -l 127.0.0.1:7200 -f ./tokens
-
在 frps 的配置文件中注册插件,并启动。
INI 格式:
# frps.ini [common] bind_port = 7000 [plugin.multiuser] addr = 127.0.0.1:7200 path = /handler ops = Login
TOML 格式:
# frps.toml bindPort = 7000 [[httpPlugins]] addr = "127.0.0.1:7200" path = "/handler" ops = ["Login"]
-
在 frpc 中指定用户名,在 meta 中指定 token,用户名以及
meta_token
的内容需要和之前创建的 token 文件匹配。user1 的配置 INI 格式:
# frpc.ini [common] server_addr = x.x.x.x server_port = 7000 user = user1 meta_token = 123 [ssh] type = tcp local_port = 22 remote_port = 6000
user1 的配置 TOML 格式:
serverAddr = "x.x.x.x" serverPort = 7000 user = "user1" metadatas.token = "123" [[proxies]] type = "tcp" localPort = 22 remotePort = 6000
user2 的配置 INI 格式:
# frpc.ini [common] server_addr = x.x.x.x server_port = 7000 user = user2 meta_token = abc [ssh] type = tcp local_port = 22 remote_port = 6001
user2 的配置 TOML 格式:
serverAddr = "x.x.x.x" serverPort = 7000 user = "user2" metadatas.token = "abc" [[proxies]] type = "tcp" localPort = 22 remotePort = 6001