不通过浏览器获取公网 IP
码农编程进阶笔记
共 1824字,需浏览 4分钟
·
2021-06-24 13:33
一.不通过浏览器获取公网 IP
有的时候我们的计算机处于受限状态,不能使用浏览器或者 HTTP 协议。
也就不能使用类似:
curl ifconfig.io
之类的命令来获取公网 IP。
但其实可以不通过浏览器,而是通过 DNS 来获取公网 IP,使用如下命令:
dig @ns1.google.com TXT o-o.myaddr.l.google.com +short
# 或者:nslookup -type=TXT o-o.myaddr.l.google.com ns1.google.com
其它的 DNS 提供商也可以:
# OpenDNS
dig myip.opendns.com @resolver1.opendns.com +short
# 或者:nslookup myip.opendns.com resolver1.opendns.com
# Akamai
dig whoami.akamai.net. @ns1-1.akamaitech.net. +short
# 或者:nslookup whoami.akamai.net. ns1-1.akamaitech.net.
这些命令会返回公网 IP 的原理是:
Google 等公司会编写程序,监听在它们类似 o-o.myaddr.l.google.com 的地址上。只要有请求,就会将请求的源 IP 地址作为数据直接返回。
二.nginx设置反向代理,如何获取真实客户端ip
upstream这个模块提供一个简单方法来实现在轮询和客户端IP之间的后端服务器负荷平衡。
upstream abc.com {
server 127.0.0.1:8080;
server 127.0.0.1:80;
server 127.0.0.1:8000;
}
server {
listen 80;
server_name www.test.com;
location / {
proxy_pass http://abc.com;
proxy_set_header Host $host;#保留代理之前的host
proxy_set_header X-Real-IP $remote_addr;#保留代理之前的真实客户端ip
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header HTTP_X_FORWARDED_FOR $remote_addr;#在多级代理的情况下,记录每次代理之前的客户端真实ip
proxy_set_header X-Forwarded-Proto $scheme;
proxy_redirect default;#指定修改被代理服务器返回的响应头中的location头域跟refresh头域数值
}
}
各参数的含义如下所示。
Host包含客户端真实的域名和端口号;
X-Real-IP表示客户端真实的IP;
X-Forwarded-For这个Header和X-Real-IP类似,但它在多层代理时会包含真实客户端及中间每个代理服务器的IP
X-Forwarded-Proto表示客户端真实的协议(http还是https);
后记:
评论
弹性公网IP EIP
百度智能云弹性公网IP EIP作为一个独立商品为用户提供公网带宽服务。用户可以将EIP实例与云服务器、负载均衡、NAT网关、VPN网关等实例绑定或解绑,为用户访问公网提供IP地址和公网带宽,做到灵活匹配业务变更,增加用户使用弹性。
百度云
0
go-ip本机网卡 IP 获取
go-ip,用于获取本机网卡全部IP。有时候需要远程获取用户本地网卡IP诊断问题,但很多普通用户不会操作,沟通成本比较高。所以写了一个小软件,传给用户双击执行即可。golang可以很方便de编译跨平台
go-ip本机网卡 IP 获取
0
树莓派4B动态解析公网IP
因为一开始采用的是Frp内网穿透技术,走的阿里云服务器的通道,所以带宽最大只支持1M,导致我本地服务器的流媒体服务访问人数一多就会引起观影卡顿,所以只能更换为DDNS技术来动态解析本地的公网IP,共试了...
MoMaek
0