找回密码
 立即注册
查看: 1484|回复: 6

[原创] [MoeRedirect]替代QC,DDNS,支持单端口反向代理,隐藏公网端口

[复制链接]

7

主题

84

回帖

532

积分

中级渣柚V2

积分
532
发表于 2020-9-21 13:33:50 | 显示全部楼层 |阅读模式
本帖最后由 code666 于 2020-9-21 13:54 编辑
5 [8 m% t! d  `
! ^2 v3 ^: ]" H9 _引言9 u2 f( e0 Y: d2 b0 y& J
       一直以来给家里和单位的群晖NAS用的都是QC+DDNS方案,也通过URL转址解决了家宽公网没有80端口的痛点(可以不加端口号访问带端口的地址),可惜由于DDNS更新存在延迟和URL转址需要进入域名提供商的网页控制台进行增加和修改,另外这个功能只能为域名所有者使用,没法做到域名共享,实在是不太方便,于是在闲暇之余,我开发了这个MoeRedirect解决了以上痛点,并增加了一些激动人心的新功能。2 V, Y+ e8 j& a& I9 r' g
关于MoeRedirect* ?- D# c* H/ {5 e# ^
       MoeRedirect(个人版)基于GO编写,支持跨平台,几乎可以覆盖所有设备,目前已编译了mipsel,arm64,amd64架构的可执行文件,可以运行在路由器,NAS或其他设备上,没有采用数据库而是采用JSON格式在本地保存数据,这是考虑到个人需要转址的条目并不多,默认端口号88。MoeRedirect提供了api,可以实时增删改相关转址信息,也可以返回客户端ip。MoeRedirect实现了2大功能,重定向(转址)和反向代理。重定向基于泛解析,根据二级域名重定向至目标地址,反向代理目前暂不支持https,可以反代本机和内网任何设备端口,于是达到了隐藏了暴露在公网的端口的目的。% W$ |3 [0 r% _4 I
使用:  j- u3 h- b3 h6 x, P/ Y& b
       目前MoeRedirect(个人版)还在测试阶段,有些需要的脚本也没写,但也向大家开放了测试,服务搭建在猫盘上,因为没有80端口,暂时只能用88端口将就着了。反向代理api暂不开放,怕内网被搞.* z0 J: v# q8 A
API:
3 }  O- j' A/ j, y4 [http://api.moeredir.site:88/api?act=[reg][del][upd][getip]&token=123456&mrid=xxx&type=redir&url=[http://xxx][https://xxx]7 P7 J& l# r4 W
api说明:act中reg为注册二级域名记录,del为删除二级域名记录,upd为更新现有二级域名记录,getip为获取客户端IP
0 S4 D: `! X$ y! ~" Dtoken在act=getip时可不加,其他都需要加) B7 J  z5 w& k! \/ i6 V
mrid为MoeRedirect ID缩写,等同于二级域名,例如mrid设置为test时,即用test.moeredir.site:88访问
* v: v7 n. A. t( d  nurl填写重定向目标地址,地址中必须带上http://或https://
8 U/ p2 U2 _* V# @API使用示例:" }$ k% L. @- A+ I6 {9 q+ f
http://api.moeredir.site:88/api?act=getip //获取客户端IP
5 \; g2 L/ `8 C' }/ Ghttp://api.moeredir.site:88/api?act=reg&token=123456&mrid=baidu&type=redir&url=http://www.baidu.com//注册一条到百度的重定向,用http://baidu.moeredir.site:88访问6 s, Q1 s2 r/ ~' q5 ?& w
http://api.moeredir.site:88/api?act=del&token=123456&mrid=baidu+ ~8 g; e( H; o3 g* w* [, X" u
//删除到百度的重定向
6 V& K( `: ~* u' S1 v3 Ehttp://api.moeredir.site:88/api?act=upd&token=123456&mrid=baidu&type=redir&url=http://www.runoob.com
4 O5 D! }5 Z9 ~8 E$ z* [  K' ]//更新到百度的重定向地址为http://www.runoob.com(菜鸟教程)- a8 L& f) e3 v* W8 ^) \6 K9 a5 i
反向代理示例:
# N7 \( ~. D, Q$ ?9 \* n) }' Q  Jhttp://test.moeredir.site:88 //反代了猫盘上的Web Station
: [! K. U% b" E* l, z% S
4 W5 u/ E& |6 z* Y8 Q* \% }: l7 V) o2 s9 N$ ?; z

9

主题

974

回帖

2575

积分

中级渣柚V3

积分
2575
发表于 2020-9-21 14:19:46 | 显示全部楼层
厉害了。。支持支持

2

主题

33

回帖

78

积分

初级渣柚V2

积分
78
QQ
发表于 2020-9-22 01:47:10 | 显示全部楼层
支持支持

2

主题

33

回帖

78

积分

初级渣柚V2

积分
78
QQ
发表于 2020-9-22 01:48:07 | 显示全部楼层
等搞懂了,可以搞个docker试试

0

主题

27

回帖

62

积分

初级渣柚V2

积分
62
QQ
发表于 2020-10-8 17:21:32 | 显示全部楼层
学习啊,不错啊

8

主题

79

回帖

4437

积分

管理员

积分
4437
发表于 2020-10-8 18:57:46 | 显示全部楼层
厉害啊。

7

主题

26

回帖

89

积分

初级渣柚V2

积分
89
QQ
发表于 2020-11-24 21:06:56 | 显示全部楼层
大佬你好,我目前也遇到了这个问题,想要通过反向代理来代替端口,不想端口暴露出来,请问应该如何操作?真心求教
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|矿渣社区 ( 黔ICP备2024020525号-1 )

GMT+8, 2025-4-20 20:33 , Processed in 0.164132 second(s), 3 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表