使用 frp 实现 windows 远程

前提条件:

拥有一台公网 ip 的服务器;

被远程控制的 windows 系统为专业版(家庭版的其它方式没有尝试过);

frp 下载包及使用说明

frp release 包的下载网址:https://github.com/fatedier/frp/releases
中文使用说明:https://gofrp.org/zh-cn/

x86_64 架构选择 amd64 即可;

在服务器上配置 frp

使用 ssh 登录服务器,切换为 root 权限;

# 进入 /opt 目录
cd /opt

# 2023-03-01 最新的版本为:0.54.0
# 下载 frp linux 包,我使用的是 x86_64 的 ubuntu 系统。
# 所以选择的下载命包为:frp_0.54.0_linux_amd64.tar.gz
# 使用 wget 下载,命令如下;下载不成功可以多尝试几次;
wget https://github.com/fatedier/frp/releases/download/v0.54.0/frp_0.54.0_linux_amd64.tar.gz

# 解压文件
tar -xzvf frp_0.54.0_linux_amd64.tar.gz

# 重命名 frp_0.54.0_linux_amd64 为 frp
mv frp_0.54.0_linux_amd64 frp

# 将 frps 移动到系统执行目录
mv frp/frps /usr/bin/frps

# 创建 frps.toml 配置文件,并填写内容如下
mkdir /etc/frp
vi /etc/frp/frps.toml

frps.toml 文件内容如下

# 客户端需要访问的端口,可以随意修改
bindPort = 6666

# 授权方式
auth.method = "token"
# 授权码,请改成更复杂的
auth.token = "aaaaa"

# dashboard 服务配置,"0.0.0.0" 为本机所有 ip
webServer.addr = "0.0.0.0"
# dashboard 配置的端口,可以随意修改
webServer.port = 6667
# dashboard 配置的用户名和密码,修改成自己的
webServer.user = "bbbbb"
webServer.password = "ccccc"

在服务器的平台上,将上述端口(6666、6667)开放出来;

端口开放界面如下图:

运行 frps 服务;

# 前台运行
frps -c /etc/frp/frps.toml

# 关闭当前服务
Ctrl + c 「快捷键」

测试 frps 服务

# 打开浏览器输入 服务器ip:dashboard端口
例:
139.224.227.14:6667

输入上面配置的用户名和密码登录;

出现以下内容界面 frps 配置 ok,如果没有出现建议百度解决;测试成功后,使用 Ctrl + c 将服务退出即可;

使用 systemd 来使 frps 服务自启动

参考说明:使用 systemd | frp

安装 systemd

1. 安装 systemd

如果您的 Linux 服务器上尚未安装 systemd,可以使用包管理器如 yum(适用于 CentOS/RHEL)或 apt(适用于 Debian/Ubuntu)来安装它:

# 使用 yum 安装 systemd(CentOS/RHEL)
yum install systemd

# 使用 apt 安装 systemd(Debian/Ubuntu)
apt install systemd

2. 创建 frps.service 文件

使用文本编辑器 (如 vim) 在 /etc/systemd/system 目录下创建一个 frps.service 文件,用于配置 frps 服务。

vi /etc/systemd/system/frps.service

写入内容

[Unit]
# 服务名称,可自定义
Description = frp server
After = network.target syslog.target
Wants = network.target

[Service]
Type = simple
# 启动frps的命令,需修改为您的frps的安装路径
ExecStart = /path/to/frps -c /path/to/frps.toml

[Install]
WantedBy = multi-user.target

3. 使用 systemd 命令管理 frps 服务

# 启动frp
systemctl start frps
# 停止frp
systemctl stop frps
# 重启frp
systemctl restart frps
# 查看frp状态
systemctl status frps

4. 设置 frps 开机自启动

systemctl enable frps

开启 windows 系统的远程功能

win10 系统

win + i 快捷键;点击系统

点击用户账户可以知道 windows 远程的用户名;一般为邮箱,密码一般为微软账号密码;

win11 系统

win + i 快捷键;点击系统,里面有远程桌面

点击远程桌面用户可以知道访问权的账户,如下示例:账户为 Tao,我的远程密码为 pin 码;

临时远程工具

可以临时使用 todesk、向日葵之类的软件来暂时远程配置电脑;

在 windows 上配置 frp,使用 stcp 的方式「配置文件方式一」

两台电脑(控制与被控制的电脑)都需要这样操作;

在 release 网站中下载合适的包 Releases · fatedier/frp · GitHub

我下载的是:frp_0.54.0_windows_amd64.zip

下载过程中浏览器和电脑防火墙会报毒,选择允许在磁盘上即可;

解压后,防火墙会报毒,然后删文件,选择允许在磁盘上,并还原删除的文件即可;

在电脑 c 盘根目录建一个 frp 文件夹,并将解压后的文件 frpc.exe 放入该目录;

# 在 frpc.exe 同级目录下,新建一个 start.txt 文件;
# 用记事本或其它软件打开 start.txt,填写内容如下:
@echo off
:home
frpc -c frpc.toml
goto home

将 start.txt 修改为 start.bat 即可;

在被控制的电脑上配置 frpc

在 frpc.exe 同级目录下,新建一个 frpc.toml 文件;

用记事本或其它软件打开 frpc.toml,填写内容如下:

# 服务器 ip 与端口配置
serverAddr = "139.224.227.14"
serverPort = 6666

# 服务器 token 配置
auth.method = "token"
auth.token = "aaaaa"

## 配置本地的端口接听,name 对于访问者来说就是 serverName
[[proxies]]
name = "stcp-home"
type = "stcp"
secretKey = "liangtao1996"
# 本地需要访问的 ip 与端口
localIP = "127.0.0.1"
localPort = 3389
## 配置本地的端口接听结束

在控制的电脑上配置 frpc

在 frpc.exe 同级目录下,新建一个 frpc.toml 文件;

用记事本或其它软件打开 frpc.toml,填写内容如下:

# 服务器 ip 与端口配置
serverAddr = "139.224.227.14"
serverPort = 6666

# 服务器 token 配置
auth.method = "token"
auth.token = "aaaaa"

## 访问者的配置
[[visitors]]
name = "stcp-vcompany"
type = "stcp"
serverName = "stcp-home"
secretKey = "liangtao1996"
bindAddr = "127.0.0.1"
bindPort = 6000
## 访问者的配置完毕

运行 frpc 服务

在两台电脑上分别双击 start.bat;frpc 服务就会运行;此时不关闭 cmd 窗口;

在控制的电脑上执行快捷键 win + r

输入 mstsc 回车

 

会出现以下界面

输入 127.0.0.1:6000 回车后,输入被控制电脑的用户名和凭据,即可进行 windows 远程;

这样就能远程内网的电脑了;

在 windows 上配置 frp,使用 xtcp 的方式「配置文件方式二」

xtcp 不一定成功,与 stcp 的配置文件的差别就是将 stcp 修改为 xtcp 即可。

xtcp 远程的流量不经过云服务器。

在被控制的电脑上配置 frpc

frpc.toml 文件修改如下:

# 服务器 ip 与端口配置
serverAddr = "139.224.227.14"
serverPort = 6666

# 服务器 token 配置
auth.method = "token"
auth.token = "aaaaa"

## 配置本地的端口接听,name 对于访问者来说就是 serverName
[[proxies]]
name = "xtcp-home"
type = "xtcp"
secretKey = "liangtao1996"
# 本地需要访问的 ip 与端口
localIP = "127.0.0.1"
localPort = 3389
## 配置本地的端口接听结束

在控制的电脑上配置 frpc

frpc.toml 文件修改如下:

# 服务器 ip 与端口配置
serverAddr = "139.224.227.14"
serverPort = 6666

# 服务器 token 配置
auth.method = "token"
auth.token = "aaaaa"

## 访问者的配置
[[visitors]]
name = "xtcp-vcompany"
type = "xtcp"
serverName = "xtcp-home"
secretKey = "liangtao1996"
bindAddr = "127.0.0.1"
bindPort = 6000
## 访问者的配置完毕

在 windows 上配置 frp,使用 xtcp 与 stcp 的方式「配置文件方式三」

在官方的手册上给出了 xtcp 不行的时候转为 stcp 方式的配置;

参考链接:XTCP | frp

控制与被控制的电脑完全可以配置调转来实现反控制,所以修改如下,可以两台电脑相互控制。

在被控制的电脑上配置 frpc

frpc.toml 文件修改如下:

# 服务器 ip 与端口配置
serverAddr = "139.224.227.14"
serverPort = 6666

# 服务器 token 配置
auth.method = "token"
auth.token = "aaaaa"

# 先试用 xtcp 打洞,失败后尝试使用 stcp
[[visitors]]
name = "stcp-vhome"
type = "stcp"
serverName = "stcp-company"
secretKey = "liangtao1996"
bindPort = -1

[[visitors]]
name = "xtcp-vhome"
type = "xtcp"
serverName = "xtcp-company"
secretKey = "liangtao1996"
bindAddr = "127.0.0.1"
bindPort = 6000
fallbackTo = "stcp-vhome"
fallbackTimeoutMs = 200
# stcp、xtcp 客户端配置完毕

# 配置本地的端口接听
[[proxies]]
name = "xtcp-home"
type = "xtcp"
secretKey = "liangtao1996"
localIP = "127.0.0.1"
localPort = 3389

[[proxies]]
name = "stcp-home"
type = "stcp"
secretKey = "liangtao1996"
localIP = "127.0.0.1"
localPort = 3389
# 配置本地的端口接听结束

在控制的电脑上配置 frpc

frpc.toml 文件修改如下:

# 服务器 ip 与端口配置
serverAddr = "139.224.227.14"
serverPort = 6666

# 服务器 token 配置
auth.method = "token"
auth.token = "aaaaa"

# 先试用 xtcp 打洞,失败后尝试使用 stcp
[[visitors]]
name = "stcp-vcompany"
type = "stcp"
serverName = "stcp-home"
secretKey = "liangtao1996"
bindPort = -1

[[visitors]]
name = "xtcp-vcompany"
type = "xtcp"
serverName = "xtcp-home"
secretKey = "liangtao1996"
bindAddr = "127.0.0.1"
bindPort = 6000
fallbackTo = "stcp-vcompany"
fallbackTimeoutMs = 200
# stcp、xtcp 客户端配置完毕

# 配置本地的端口接听
[[proxies]]
name = "xtcp-company"
type = "xtcp"
secretKey = "liangtao1996"
localIP = "127.0.0.1"
localPort = 3389

[[proxies]]
name = "stcp-company"
type = "stcp"
secretKey = "liangtao1996"
localIP = "127.0.0.1"
localPort = 3389
# 配置本地的端口接听结束

在 windows 上配置 frpc 自启动

建议将 frpc.exe 添加到防火墙的忽略文件中

 点击「病毒和威胁防护」=>「管理设置」

点击「添加或删除排除项」=> 「添加排除项」

设置自启动

过程如下:

1. win 键,输入 任务计划程序

2. 点击 操作 => 创建任务

3. 名称填 frpc
   选择 不管用户是否登录都有运行(W)
   		勾选 不存储密码(P)。该任务只有访问本地计算机资源的权限。
   勾选 使用最高权限运行(I)
   勾选 隐藏(E) 配置(C):Windows 10
   
4. 点击 触发器
   点击 新建(N)
   开始任务(G):启动时
   勾选延迟任务时间(K):30秒
   点击 确定
   
5. 点击 操作
   点击 新建(N)
   程序或脚本(P):
   填写或选择路径为:C:\frp\start.bat
   起始于(可选)(T):填写目录为 C:\frp
   
6. 点击 条件
   勾选 只有在计算机使用交流电源时才启动此任务(P)
   		勾选 如果计算机改用电池电源,则停止(B)
   勾选 只有在以下网络连接可用时才启动(Y)
   		任何连接
   		
   		点击 确定

设置好后,重启电脑,即可在任务管理器中看到 frpc 正在运行中;

frps.toml 以及 frpc.toml 参考

# frpc.toml 参考
https://github.com/fatedier/frp/blob/dev/conf/frpc_full_example.toml

# frps.toml 参考
https://github.com/fatedier/frp/blob/dev/conf/frps_full_example.toml

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值