Skip to content
/ fcn Public
forked from replive/fcn

free connect your private network from anywhere

Notifications You must be signed in to change notification settings

Scorpi000/fcn

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

FCN

free connect your private network from anywhere

1. FCN简介

FCN[free connect]是一款闭源傻瓜式的一键接入私有网络的工具, fcn利用公共服务器以及数据加密技术实现:

在免公网IP环境下,在任意联网机器上透明接入服务端所在局域网网段

FCN = 用户服务端 <--- FCN公共服务器 --- > 用户客户端

  • FCN使用交流QQ群: 822475769 592512533(已满) 请务必填写加群理由(FCN使用交流)

  • FCN支持操作系统平台

操作系统 文件名 下载地址
Windows操作系统 fcn_win.exe https://github.com/boywhp/fcn/releases/download/FCN_V3.8/fcn_win.zip
Debian GTK版本 fcn.deb https://github.com/boywhp/fcn/releases/download/FCN_V3.8/fcn.deb
MacOS操作系统 fcn_mac.app https://github.com/boywhp/fcn/releases/download/FCN_V3.8/fcn_mac.zip
Android fcn.apk https://github.com/boywhp/fcn/releases/download/FCN_V3.8/fcn.apk
Linux/嵌入式Linux fcn_x64/x86/... https://github.com/boywhp/fcn/releases/download/FCN_V3.8/fcn_linux.zip

Linux openwrt/lede WR703N、华硕N14U、斐讯K2/K2P Openwrt/Padavan实测通过,openwrt/lede需自行安装libopenssl

Linux arm/armbian 树莓派3、Orange Pi实测通过

  • FCN WIKI页面已经开放编辑[请大家一齐完善FCN文档]

https://github.com/boywhp/fcn/wiki

FCN(Windows版)一键接入局域网操作视频

image

2. FCN实际案例

使用FCN跨互联网组网

https://github.com/boywhp/fcn/blob/master/doc/FCN%E5%AE%9E%E9%99%85%E6%A1%88%E4%BE%8B1.ppt

使用FCN远程唤醒PC,并远程管理

https://github.com/boywhp/fcn/blob/master/doc/FCN%20%E6%A1%88%E4%BE%8B2.ppt

3. FCN使用

3.1 运行客户服务端

FCN默认加载当前目录下的fcn.conf配置文件,用户也可以手工指定

测试帐户[仅供个人测试使用]: FCN_0000-FCN_9999, 限速100KB/s,日流量配额150M [P2P成功后无速度流量限制]

请用户随机挑选测试帐户,并设置唯一服务端名称,以免帐户冲突

配置键值 描述
[uid] 你的付费帐户名或者FCN_[0001-9999] 8字符FCN ID
[uic] 你的付费帐户8位识别码
[name] 服务器名,建议填写一个有意义的名称
[psk] 管理员账号密码hash或者明文密码,建议使用hash
[cipher] 指定加密算法【aes-256-cfb/aes-128-cfb/chacha20】,默认aes-256-cfb
[authfile] 用户列表文件名,用户列表文件使用fcn_win.exe获取
[log] 指定服务端日志输出文件, 默认不输出日志
[compress] 指定是否开启数据包压缩,默认1开启
[udp] 0/1, 设置数据包通信类型 0:TCP 1:UDP,建议不填使用UDP
[nat_nic] 虚拟接入后连接的服务器网卡名, 建议不填
[dhcp_ip/dhcp_mask/dhcp_dns] 虚拟接入后DHCP网段, DHCP DNS服务器地址, 建议不填
[uport] 自定义udp通信端口, 默认5000,自定义[1000-2000], 建议不填
[tport] 自定义tcp通信端口, 默认8000,自定义[1000-2000], 建议不填
[pport] 自定义p2p通信端口, 除非服务端可做端口映射,否则不要填
[host] 设置公网FCN服务器地址,默认free.xfconnect.com, 建议不填
[notun] 0/1, 0:自动 1:强制应用层NAT,建议不填
[portmap] 0/1, 是否开启服务端端口转发, 视情填写
[route] 设置路由网段推送列表, 视情填写

tun驱动模式NAT,需要ROOT权限运行;应用层NAT模式,非ROOT权限无法收发ping包

./fcn_x64         # 应用层NAT模式
sudo ./fcn_x64    # tun驱动NAT模式

注:FCN服务端一个配置只能运行一个实体, 更改配置后, 需要kill掉旧的进程, 否则会提示错误

3.2 开机自启动-嵌入式Linux

3.2.1 树莓派3[Thanks to 榭寄生], debian linux环境

  • 建立启动脚本 fcn.sh, 内容如下:
#!/bin/sh
/home/pi/fcn-arm
  • 添加执行权限 chmod +x fcn.sh

  • 创建软链接 ln -s /home/pi/your_fcn_dir/fcn.sh /etc/init.d/fcn

  • 添加自启动 update-rc.d fcn defaults 99

3.2.2 斐讯K2路由器-Padavan

[uid]=FCN_1234
[psk]=YOUR_PASSWORD
[name]=PSG_K2
[nat_nic]=br0
[notun]=1
  • 使用winscp或者xshell上传fcn_mipsel以及fcn.conf到/etc/storage/fcn/目录
  • 加执行权限 chmod +x /etc/storage/fcn
  • 登陆路由器Web界面 高级设置->自定义->脚本->WAN 上行/下行 事件后运行, 添加如下代码
if [ $1 = "up" ] ; then
    /etc/storage/fcn/fcn_mipsel
fi
  • 重启路由器

3.2.3 斐讯K2P路由器博通版-Merlin

  • 登录路由器打开ssh服务[梅林固件默认不开ssh服务]
  • 编辑fcn.conf配置文件模板如下:
[uid]=FCN_1234
[psk]=YOUR_PASSWORD
[name]=MERLIN_K2P
[nat_nic]=br0
[notun]=1
  • mkdir /jffs/fcn
  • 使用winscp或web控制台上传openwrt/fcn_armhf以及fcn.conf到/jffs/fcn目录
  • chmod +x /jffs/fcn/fcn_armhf
  • 添加自定义Wan连接成功脚本
#!/bin/sh
modprobe tun
/jffs/fcn/fcn_armhf
  • 重启路由器

3.3 运行windows客户端

主界面添加服务器, 填写对应的连接参数, 连接, 成功后, windows客户端即接入了服务器对应局域网, 客户端/服务端参数对应如下

image

注:第一次连接时会自动安装虚拟网卡驱动,需用户确认同意

3.4 运行Linux客户端

Linux客户端/服务端功能已整合在同一个可执行文件中,客户端最常见参数如下:

sudo ./fcn --uid FCN_0001 --name SVR0001 --psk 'PASSWORD'
sudo ./fcn --cfg client.conf

Linux客户端配置文件参数如下:

参数名 描述
[uid] 对应服务端用户ID参数
[psk] 对应服务端用户连接密码参数, 必须是明文
[name] 对应服务端服务器名
[usr] 对应服务端用户名
[host] FCN公共服务器地址,默认free.xfconnect.com,建议直接填写对应的ip地址
[tun] 指定客户端虚拟网卡的名称,默认tun_fcn,建议多个FCN客户端时填写
[tun_ip] 手工指定客户端虚拟网卡IP地址
[udp] 设置数据包通信类型,0:TCP/1:UDP,默认1 UDP,建议默认
[vpn] 是否开启全局路由,默认接入服务端网卡网段,建议按需填写
[fwd] 开启服务端局域网数据自动转发到虚拟网卡,建议按需开启
[log] 指定服务端日志输出文件, 默认不输出日志
[client] 1/0,指示客户端模式运行,必须填1
[compress] 指定是否开启数据包压缩,默认1开启

4. FCN安全吗?

FCN使用了数字证书、tls以及数据加密技术,点对点通信技术, 用户网络数据全程加密,60分钟左右自动更新会话密钥,确保用户数据不会被截获解密或者中间人欺骗。

FCN公网服务器不会收集和保存用户的任何敏感数据, 公共服务器只负责转发加密报文, 无法解密用户网络数据包, 同时支持用户网络数据强制点对点通信。

4.1 FCN安全机制

  • FCN公网服务器和fcn客户端之间通过TLS证书双向验证确保信道安全
  • FCN用户服务端每60分钟向fcn公网服务器请求随机数
  • FCN公网服务器使用真随机数发生器产生随机数, 并通过TLS连接安全传递给用户
  • FCN客户端/服务端通过 随机码 + UID + PSK 计算出一个会话key
  • FCN客户端/服务端使用会话key对通信数据包全程aes256加密

5. 免责声明

请您仔细阅读以下声明,您在使用FCN工具软件以及使用FCN企业订制服务,表明您对以下内容的接受:

  • 严禁破解,逆向本系统程序及相关组件,违者不但将不再享受官方提供的任何服务,也将承担法律责任,并赔偿相应损失;
  • 本软件属于正规网络接入软件,请合理,合法的使用本软件产品;切勿用于违反法律,道德及影响他人利益的活动;如果因用于非法用途,由此造成的不良后果,由用户自行负责,本软件开发者不承担任何责任及损失。

About

free connect your private network from anywhere

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C 88.6%
  • Shell 11.4%