最近突然发现公司 ping google 会被解析为内网 ip
xxx@xxx ~ % ping google.com
PING google.com (10.xx.xx.xxx): 56 data bytes
64 bytes from 10.xx.xx.xxx: icmp_seq=0 ttl=56 time=54.002 ms
64 bytes from 10.xx.xx.xxx: icmp_seq=1 ttl=56 time=52.970 ms
64 bytes from 10.xx.xx.xxx: icmp_seq=2 ttl=56 time=52.414 ms
然后通过 dig 查看了一下,发现使用公司的内网 dns 会被解析到三个内网 ip ,如果使用公共 dns 就会解析到公网 ip 上,看了一下 google 的证书,和科学上网访问的证书是同一本( SHA-256 指纹判定),想问一下这个是怎么实现的呢?这不就是中间人攻击吗
补充,访问 CloudFront 加速的网站也会被解析到和 Google 相同的内网 ip 上,并且证书和公网访问一样
1
cjpjxjx 309 天前 via iPhone
反向代理吧
|
3
xfn 309 天前
应该是虚拟 IP ,类似于 Surge 的做法
|
6
seers 309 天前 via iPhone
fakeip
|
7
jemyzhang 309 天前 via iPhone
类似 fakeip ?
|
8
MeteorVIP 309 天前 via iPhone
tun 模式吧
|
9
onetown 309 天前 4
sni proxy 吧
|
10
kneo 309 天前 via Android
证书对就行。IP 无所谓。
|
11
SenLief 309 天前 1
类似于 fakeip 吧
|
12
shenyuzhi 309 天前
三层转发了一下而已
https 是四层的 |
13
yumusb 309 天前
你们内网 time=54.002 ms 这走的什么隧道组的内网。。
|
14
paranoiagu 309 天前 via Android
不就是 fakeip 方式分流么
|
18
beyondstars 309 天前 4
请你复习一遍 OSI 网络参照模型,HTTP 协议位于应用层。
另外如果你愿意你甚至可以把任意一个域名(例如 example.com )解析为 127.0.0.1 ,然后通过 https://example.com 访问本机 443 端口提供的这个网站,只需要做一个 TCP 转发 (127.0.0.1:443 -> <remote-ip>:443)。类似的名称(功能):虚拟 IP ,端口转发,4 层反向代理,都可以做到这一点。你想想 Kubernetes Service 的 ClusterIP 是怎么实现的。 中间人攻击不存在,除非中间人能解密 HTTPS 流量,或者你信任了中间人签发的根证书。 |
19
beyondstars 309 天前
例如通过 nginx 就可以配一个端口转发,把本机 443 端口转发到 任意一个网站的 的 IP 的 443 端口,配置也很简单: https://docs.nginx.com/nginx/admin-guide/load-balancer/tcp-udp-load-balancer/
|
20
mytsing520 309 天前
正向代理+隧道
|
21
beyondstars 309 天前
https://www.haproxy.com/blog/layer-4-and-layer-7-proxy-mode 这篇文章介绍了七层反向代理和 四层反向代理的区别,七层反向代理的转发器需要解析 HTTP 报文,重新发送 HTTP 报文,所以才需要证书。
四层的不需要。就好像你家的路由器也在转发你访问任意网站的流量,但是它不需要证书。 |
22
orzorzorzorz 309 天前
@basncy 借楼一问。op 这是啥输入法,我乍一看回复以为是屏幕脏了,但复制出去才发现这字有东西。
|
24
ZhiyuanLin 309 天前
你用 haproxy 或者 iptables 自己的 VPS 搞个转发就知道了。
|
25
cloverzrg2 309 天前
公司帮你搭了个正向代理
|
26
BeiChuanAlex 309 天前
也许是专线
|
27
notabigdirector 308 天前
这些知识都是怎么学的,感觉好复杂,看博客都是一些看不懂的专业术语
|
28
wuvvu 308 天前 1
|
29
JK2333 308 天前
把你 cfw 的 tun 模式关了就行····
|
30
tywtyw2002 308 天前
我看怎么是 虚拟 ip 然后做路由呢,很可能连 SNI proxy 都不算,直接走得是 3 层路由过 VPN 了,然后出口在做 NAT ,简单方便。
是不是 SNI proxy 你要看 tcp 建立的时间,毕竟 SNI proxy 要先 tcp 连接了 读 SNI ,然后代理才会去请求源。 traceroute 下试试看。 |
31
Rorysky 308 天前
@notabigdirector 中国程序员网络知识 天下第一,都得改写 gfw
|
32
louisxxx 307 天前 via iPhone
端口转发
|