亲测使用frp获得访问者真实ip

怎么访问都只有127.0.0.1这个内网ip,获取不到访问者的真实ip
1.打开frp的配置文件(一般是frpc.toml,无需设置frps.toml)
在每一个tcp协议中添加
transport.proxyProtocolVersion = "v2"
实例:
# frpc.toml

[[proxies]]
name = "web"
type = "tcp"
localPort = 73
remotePort = 73
# now v1 and v2 are supported
transport.proxyProtocolVersion = "v2"

如果要实现效果:

1、保持原服务器的73端口可以继续正常访问

2、转发服务器也可以使用端口73端口访问

可在原服务器在创建一个和73端口相同的网站,端口设置为77即可,同时使用下面的配置信息。

# frpc.toml

[[proxies]]
name = "web"
type = "tcp"
localPort = 77
remotePort = 73
# now v1 and v2 are supported
transport.proxyProtocolVersion = "v2"

重新启动frp:

/root/frp_0.58.0_linux_amd64/frpc -c /root/frp_0.58.0_linux_amd64/frpc.toml 

如果运行没有问题的情况时下,也可以使用下面命令进入后台运行 :

nohup /root/frp_0.58.0_linux_amd64/frpc -c /root/frp_0.58.0_linux_amd64/frpc.toml&

使用ps a查看pid号后,使用kill -9 pid号结束进程

这时,你会发现网站打不开了,这里需要在网站配置文件中修改

2.打开宝塔面板(打开网站配置文件)

依次点击网站-设置(前提你创建了网站)-配置文件

你会看见listen这个单词,在每个listen的末尾(也就是" ; "前)添加下列代码
proxy_protocol
变成:
listen 88 proxy_protocol;
listen 443 ssl http2 proxy_protocol;
注意离前面一个有空格

然后在root后添加下列代码
real_ip_header proxy_protocol;
real_ip_recursive on;
set_real_ip_from x.x.x.x;
注意:x.x.x.x为frp客户端的ip地址,一般填写127.0.0.1

即:

real_ip_header proxy_protocol;
real_ip_recursive on;
set_real_ip_from 127.0.0.1;

最终修改如下图所示:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值