获取访问者真实ip地址?我觉得不可能
我们真的能通过请求来获取用户真实的ip地址嘛?
答案是不能,如果能,肯定是我学的不够深入,欢迎交流指正。
那么写这篇文章的意义是什么?我们接着往下看。
IP地址相当于电脑在网络上的身份证,但事实上IP地址却没有想象中那么简单,IP也分很多种,比如经常提到内网IP和外网IP。
外网ip和内网ip的区别是什么?
因为这个网络太复杂,讲解时牵扯到的东西太多,没法简单地描述,长篇大论对初学者是极不友好的;如果非要简单地讲解又必然会有遗漏,可能会对你以后产生误导。
我自己也对这个是比较模糊的,我就按照自己的理解大概解释一遍。但是我讲的不一定是对的。
我家里的路由器是电信的,路由器上面连接一根电信的电话线,这跟电话线是要我家去电信缴费,才能上网。我家路由器能上网之后,就能打开wifi,我的其他设备就能通过wifi连接上这台路由器。

上面介绍了个大概,接下来说说java端如何获取访问者 IP ?,先上代码
@Slf4j
public class IpUtil { /**
* 获取用户ip地址
*
* @param request 请求
* @return ip地址
*/
public static String getIpAddr(HttpServletRequest request) { String ipAddress = request.getHeader("X-Original-Forwarded-For");
log.info("X-Original-Forwarded-For:获取的ipAddress{}",ipAddress); if (ipAddress == null || ipAddress.length() == 0 || "unknown".equalsIgnoreCase(ipAddress)) {
ipAddress = request.getHeader("X-Forwarded-For");
log.info("X-Forwarded-For:获取的ipAddress{}",ipAddress);
}
// 对于通过多个代理的情况,因为ip长度最大为15,如果超过了15就代表有1个以上的ip,这时我们就取第一个,多个IP按照','分割
if (ipAddress != null && ipAddress.length() > 15) {
log.info("多个ip情况:获取的ipAddress:{}",ipAddress);
if (ipAddress.indexOf(",") > 0) {
ipAddress = ipAddress.substring(0, ipAddress.indexOf(","));
}
} if (ipAddress == null || ipAddress.length() == 0 || "unknown".equalsIgnoreCase(ipAddress)) {
// apache http服务器的请求
ipAddress = request.getHeader("Proxy-Client-IP");
log.info("Proxy-Client-IP:获取的ipAddress{}",ipAddress);
}
if (ipAddress == null || ipAddress.length() == 0 || "unknown".equalsIgnoreCase(ipAddress)) {
// apache http服务器的请求,使用weblogic插件加上的头
ipAddress = request.getHeader("WL-Proxy-Client-IP");
log.info("WL-Proxy-Client-IP:获取的ipAddress{}",ipAddress);
}
if (ipAddress == null || ipAddress.length() == 0 || "unknown".equalsIgnoreCase(ipAddress)) {
// 有些代理服务器会加上此请求头
ipAddress = request.getHeader("HTTP_CLIENT_IP");
log.info("HTTP_CLIENT_IP:获取的ipAddress{}",ipAddress);
}
if (ipAddress == null || ipAddress.length() == 0 || "unknown".equalsIgnoreCase(ipAddress)) { ipAddress = request.getHeader("HTTP_X_FORWARDED_FOR");
log.info("HTTP_X_FORWARDED_FOR:获取的ipAddress{}",ipAddress);
}
if (ipAddress == null || ipAddress.length() == 0 || "unknown".equalsIgnoreCase(ipAddress)) {
// nginx代理服务器会加上此请求头
ipAddress = request.getHeader("X-Real-IP");
log.info("X-Real-IP:获取的ipAddress{}",ipAddress);
} // 没有使用代理的情况
if (ipAddress == null || ipAddress.length() == 0 || "unknown".equalsIgnoreCase(ipAddress)) {
ipAddress = request.getRemoteAddr();
log.info("request.getRemoteAddr()------->{}",ipAddress);
} // 如果用localhost来访问会返回0:0:0:0:0:0:0:1,这里我们将它转换为127.0.0.1
return "0:0:0:0:0:0:0:1".equals(ipAddress)?"127.0.0.1":ipAddress;
} }
这段代码看起来很长,其实有用的部分就是 request.getRemoteAddr();
其他情况,都是根据目前常用的代理商使用的请求头类型来获取ip地址。
比如以下几种情况:
X-Original-Forwarded-For
Proxy-Client-IP
HTTP_CLIENT_IP
HTTP_X_FORWARDED_FOR
这些都是一些常用的,因为这个请求头类型是可以自定义的,所以我们根据请求头类型获取ip地址是不现实的。
但是为什么代码里面要写呢?人情世故嘛,万一公司是按代码行数算工资的呢。哈哈,开个玩笑,已知的代理请求头,我们还是需要写上去的。
不结合客户使用场景的光讨论技术都是耍流氓。下面我们重点说一下使用场景。
1、上面那段代码部署在外网环境,那么获取到的就是外网的ip,要是别人没有经过伪装,恭喜你,成功拿到他的ip。要是别人特意伪装,你拿到这个ip或许是假的,没有任何意义。
2、上面那段代码部署在内网环境,那么获取到的就是内网ip,这个内网ip,就能查出具体某台电脑,也能在内网中远程控制你的电脑。
上面两个场景都是人畜无害。
一般是第二种情况使用的多。
比如你的公司有20层,公司所有员工都是用内网,你在20楼,你的同事在1楼,恰好你们公司没有电梯,此时你想控制他的电脑,帮她处理一些事情,你就可以让她直接访问那段代码,获取到她的ip地址。当然,代码肯定是封装成一个接口,不然妹子怎么访问。
什么?远程不用向日葵?TV?QQ?
哈哈,是我格局小了。
什么?直接叫妹子从电脑查看ip地址发给我?
哈哈,是我格局小了。我就怕妹子不会看啊。
难不成让她自己百度怎么查看ip地址?老实说,有这种想法的是不是还单身?
好了,对于获取ip地址,网上也是各种形形色色,但是要明确使用场景,如果你真的想通过一个ip地址去追寻到一个人或者一台电脑,在公网环境下,有点不现实。但是在内网环境中,这个确实可行。
获取访问者真实ip地址?我觉得不可能的更多相关文章
- 获取客户端真实IP地址
Java-Web获取客户端真实IP: 发生的场景:服务器端接收客户端请求的时候,一般需要进行签名验证,客户端IP限定等情况,在进行客户端IP限定的时候,需要首先获取该真实的IP. 一般分为两种情况: ...
- 伪造IP及获取客户端真实IP地址
Fiddler支持自定义规则,可以实现对HTTP请求数据发送给Server前或HTTP应答数据发送给浏览器前进行修改.下面的例子将演示如何向所有HTTP请求数据中增加一个头.1)打开Fiddler,点 ...
- Java中使用HttpRequest获取用户真实IP地址端口
import javax.servlet.http.HttpServletRequest; /** * 自定义访问对象工具类 * * 获取对象的IP地址等信息 * @author X-rapido * ...
- Java获取客户端真实IP地址
Java代码 import javax.servlet.http.HttpServletRequest; /** * 获取对象的IP地址等信息 */ public class IPUtil { /** ...
- Java 获取客户端真实IP地址
本文基于方法 HttpServletRequest.getHeader 和 HttpServletRequest.getRemoteAddr 介绍如何在服务器端获取客户端真实IP地址. 业务背景 服务 ...
- java如何获取访问真实IP地址?
java如何获取访问真实IP地址 解决方法: 获取请求主机IP地址,如果通过代理进来,则透过防火墙获取真实IP地址,如果没有代理,则获取真实ip public static String getIp( ...
- 7个获取访问者真实IP的方法,速学!!!
通常情况下,网站访问并不是简单地从用户的浏览器直达服务器,中间可能部署有CDN.WAF.高防.例如,采用这样的架构:“用户 > CDN/WAF/高防 > 源站服务器” .那么,在经过多层代 ...
- CDN下nginx获取用户真实IP地址
随着nginx的迅速崛起,越来越多公司将apache更换成nginx. 同时也越来越多人使用nginx作为负载均衡, 并且代理前面可能还加上了CDN加速,但是随之也遇到一个问题:nginx如何获取用户 ...
- LNAMP架构中后端Apache获取用户真实IP地址的2种方法(转)
一.Nginx反向代理配置: 1.虚拟主机配置 复制代码代码如下: location / { try_files $uri @apache;} location @apache {interna ...
随机推荐
- Jenkins+Sonar 项目构建前代码审查
一.sonar简介 1.概述 Sonar (SonarQube)是一个开源平台,用于持续检查代码质量,不只是一个质量数据报告工具,更是代码质量管理平台. 支持Java, C#, C/C++, PL/S ...
- 公钥-私钥 白名单-黑名单 Linux 远程访问及控制(SSH)
远程访问及控制一.SSH远程管理二.OpenSSH服务器① SSH (Secure Shell)协议② OpenSSH三.配置OpenSSH服务器举例四.sshd 服务支持两种验证方式五.使用SSH客 ...
- C语言:char总结
char字符型数据1.用单引号限制的1字节的字符称为字符型数据,字符型常量2.字符型常量实质保存的是对应字符的ASCII码值,是一个整数3.字符型常量表示范围:0-2554.声明字符型变量 char ...
- Day11继承、封装、多态-面向对象编程(2)
封装 我们设计程序要追求 高内聚,低耦合 . 高内聚:类的内部数据操作细节自己完成,不允许外部干涉 低耦合:仅暴露少量方法给外部使用 封装(数据的隐藏) 通常,应禁止直接访问一个对象中数据的实际表示, ...
- C++ Primer Plus 第四章 复合类型 学习笔记
第四章 复合类型 1. 数组概述 1.1 数组的定义 数组(array)是一种数据格式,能够存储多个同类型的值.每个值都存储在一个独立的数组元素中,计算机在内存中依次存储数组的各个元素. 数组声明的三 ...
- c# 将checkedListBox选择的值保存再数组中并转换成以指定字符连接的字符串
经常忘记,所以记一下: string[] arr =new string[3]; int b = 0; foreach (string outstr in checkedListBox1.Checke ...
- Redis主从复制那点事
我们在 Redis持久化机制你学会了吗?学习了AOF和RDB,如果Redis宕机,他们分别通过回放日志和重新读入RDB文件的方式恢复数据,从而提高可靠性.我们今天来想这么一个问题,假如我们 ...
- CF459E-DP
CF459E-DP 核心代码15行 思路 观察数据范围,我们建m层分层图跑最短路想到DP. DP最大的特点就是无后效性.那么我们这一题哪个条件无后效性呢? 发现DP值一定从边权小于当前点的位置转移而来 ...
- 第4天 JavaDoc生成文档&Java流程控制(第一节:用户交互Scanner)
JavaDoc生成文档 javadoc命令是用来生成自己的API文档 参数信息: @author 作者名 @version 版本号 @since 指明需要最早使用的jdk版本 @param 参数名 @ ...
- 2019版pycharm永久激活
链接:https://pan.baidu.com/s/1vY1KBvi2NHIgoN8C2qaFbg 提取码:p4gx 1.下对应版本的jar包,放到pycharm目录的bin目录下2.去C:\Use ...