pom

<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-core</artifactId>
</dependency>
<dependency>
<groupId>commons-lang</groupId>
<artifactId>commons-lang</artifactId>
<version>2.6</version>
<scope>compile</scope>
</dependency>
 /**
* 获取访问者IP
* 在一般情况下使用Request.getRemoteAddr()即可,但是经过nginx等反向代理软件后,这个方法会失效。
* 本方法先从Header中获取X-Real-IP,如果不存在再从X-Forwarded-For获得第一个IP(用,分割),
* 如果还不存在则调用Request .getRemoteAddr()。
* @param request
* @return
*/
public static String getIpAddr(HttpServletRequest request) {
String ip = request.getHeader("X-Real-IP");
if (!StringUtils.isBlank(ip) && !"unknown".equalsIgnoreCase(ip)) {
if(ip.contains("../")||ip.contains("..\\")){
return "";
}
return ip;
}
ip = request.getHeader("X-Forwarded-For");
if (!StringUtils.isBlank(ip) && !"unknown".equalsIgnoreCase(ip)) {
// 多次反向代理后会有多个IP值,第一个为真实IP。
int index = ip.indexOf(',');
if (index != -1) {
ip= ip.substring(0, index);
}
if(ip.contains("../")||ip.contains("..\\")){
return "";
}
return ip;
} else {
ip=request.getRemoteAddr();
if(ip.contains("../")||ip.contains("..\\")){
return "";
}
if(ip.equals("0:0:0:0:0:0:0:1")){
ip="127.0.0.1";
}
return ip;
} }

最新文章

  1. mysql nonInstall 版本的安装与配置
  2. 电改:OPower资料调研
  3. JavaScript 五种(非构造方式)继承
  4. 拟物设计和Angular的实现 - Material Design(持续更新)
  5. SharePoint 禁用本地回环的两个方法
  6. Tomcat热部署和虚拟目录配置
  7. cmd 里面运行git提示“不是内部或外部命令,也不是可运行的程序”的解决办法
  8. FM笔记
  9. 今天才知道mysql
  10. Android中Activity之间访问互传参数
  11. js上拉跳转原理
  12. 为HTTP分类作序
  13. 安卓开发中Spinner控件的使用
  14. Swing-JTable检测单元格数据变更事件
  15. 九、 Spring Boot 拦截器
  16. angular 2+ 变化检测系列三(Zone.js在Angular中的应用)
  17. [android] android下junit测试框架配置
  18. Linux内存、性能诊断中vmstat命令的详解
  19. nginx配置框架问题
  20. dos2unix 批量转化文件

热门文章

  1. Codeforces 840E - In a Trap(树分块+trie)
  2. [Ocean Modelling for Begineers] Ch3. Basics of Geophysical Fluid Dynamics
  3. chown &amp; chmod用法
  4. 利用charles映射解决夜神模拟器安装xposed-v89-sdk25-x86.zip
  5. Ubuntu apt代理apt-cacher-ng配置及使用
  6. 13 — springboot集成mybatis-plus — 更新完毕
  7. [云原生]Docker - 镜像
  8. 求最长子序列(非连续)的STL方法 - 洛谷P1020 [NOIP1999 普及组] 导弹拦截
  9. java中的collection小结
  10. android转换透明度