电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

淺談使用Java Web獲取客戶端真實(shí)IP的方法示例詳解

瀏覽:7日期:2022-08-29 10:36:34

Java-Web獲取客戶端真實(shí)IP:

發(fā)生的場景:服務(wù)器端接收客戶端請求的時候,一般需要進(jìn)行簽名驗(yàn)證,客戶端IP限定等情況,在進(jìn)行客戶端IP限定的時候,需要首先獲取該真實(shí)的IP。

一般分為兩種情況:

方式一、客戶端未經(jīng)過代理,直接訪問服務(wù)器端(nginx,squid,haproxy);

方式二、客戶端通過多級代理,最終到達(dá)服務(wù)器端(nginx,squid,haproxy);

客戶端請求信息都包含在HttpServletRequest中,可以通過方法getRemoteAddr()獲得該客戶端IP。

方式一形式,可以直接獲得該客戶端真實(shí)IP。

方式二中通過代理的形式,此時經(jīng)過多級反向的代理,通過方法getRemoteAddr()得不到客戶端真實(shí)IP,可以通過x-forwarded-for獲得轉(zhuǎn)發(fā)后請求信息。當(dāng)客戶端請求被轉(zhuǎn)發(fā),IP將會追加在其后并以逗號隔開,例如:10.47.103.13,4.2.2.2,10.96.112.230。

請求中的參數(shù):

request.getHeader('x-forwarded-for'):10.47.103.13,4.2.2.2,10.96.112.230

request.getHeader('X-Real-IP'):10.47.103.13

request.getRemoteAddr():10.96.112.230

客戶端訪問經(jīng)過轉(zhuǎn)發(fā),IP將會追加在其后并以逗號隔開。最終準(zhǔn)確的客戶端信息為:

x-forwarded-for 不為空,則為逗號前第一個IP ; X-Real-IP不為空,則為該IP; 否則為getRemoteAddr() ;

相關(guān)請求頭的解釋:

X-Forwarded-For :這是一個 Squid 開發(fā)的字段,只有在通過了HTTP代理或者負(fù)載均衡服務(wù)器時才會添加該項(xiàng)。

格式為X-Forwarded-For:client1,proxy1,proxy2,一般情況下,第一個ip為客戶端真實(shí)ip,后面的為經(jīng)過的代理服務(wù)器ip。現(xiàn)在大部分的代理都會加上這個請求頭。

Proxy-Client-IP/WL- Proxy-Client-IP :這個一般是經(jīng)過apache http服務(wù)器的請求才會有,用apache http做代理時一般會加上Proxy-Client-IP請求頭,而WL-Proxy-Client-IP是他的weblogic插件加上的頭。 HTTP_CLIENT_IP :有些代理服務(wù)器會加上此請求頭。 X-Real-IP :nginx代理一般會加上此請求頭。

/** * 獲取用戶真實(shí)IP地址,不使用request.getRemoteAddr()的原因是有可能用戶使用了代理軟件方式避免真實(shí)IP地址, * 可是,如果通過了多級反向代理的話,X-Forwarded-For的值并不止一個,而是一串IP值 */ private String getIpAddr(HttpServletRequest request) { String ip = request.getHeader('x-forwarded-for'); System.out.println('x-forwarded-for ip: ' + ip); if (ip != null && ip.length() != 0 && !'unknown'.equalsIgnoreCase(ip)) { // 多次反向代理后會有多個ip值,第一個ip才是真實(shí)ip if( ip.indexOf(',')!=-1 ){ ip = ip.split(',')[0]; } } if (ip == null || ip.length() == 0 || 'unknown'.equalsIgnoreCase(ip)) { ip = request.getHeader('Proxy-Client-IP'); System.out.println('Proxy-Client-IP ip: ' + ip); } if (ip == null || ip.length() == 0 || 'unknown'.equalsIgnoreCase(ip)) { ip = request.getHeader('WL-Proxy-Client-IP'); System.out.println('WL-Proxy-Client-IP ip: ' + ip); } if (ip == null || ip.length() == 0 || 'unknown'.equalsIgnoreCase(ip)) { ip = request.getHeader('HTTP_CLIENT_IP'); System.out.println('HTTP_CLIENT_IP ip: ' + ip); } if (ip == null || ip.length() == 0 || 'unknown'.equalsIgnoreCase(ip)) { ip = request.getHeader('HTTP_X_FORWARDED_FOR'); System.out.println('HTTP_X_FORWARDED_FOR ip: ' + ip); } if (ip == null || ip.length() == 0 || 'unknown'.equalsIgnoreCase(ip)) { ip = request.getHeader('X-Real-IP'); System.out.println('X-Real-IP ip: ' + ip); } if (ip == null || ip.length() == 0 || 'unknown'.equalsIgnoreCase(ip)) { ip = request.getRemoteAddr(); System.out.println('getRemoteAddr ip: ' + ip); } System.out.println('獲取客戶端ip: ' + ip); return ip; }

import javax.servlet.http.HttpServletRequest;/*** IP校驗(yàn)*/public class IPUtils { public static String getClientAddress(HttpServletRequest request) { if (request == null) { return 'unknown'; } String ip = request.getHeader('x-forwarded-for'); if (ip == null || ip.length() == 0 || 'unknown'.equalsIgnoreCase(ip)) { ip = request.getHeader('Proxy-Client-IP'); } if (ip == null || ip.length() == 0 || 'unknown'.equalsIgnoreCase(ip)) { ip = request.getHeader('X-Forwarded-For'); } if (ip == null || ip.length() == 0 || 'unknown'.equalsIgnoreCase(ip)) { ip = request.getHeader('WL-Proxy-Client-IP'); } if (ip == null || ip.length() == 0 || 'unknown'.equalsIgnoreCase(ip)) { ip = request.getHeader('X-Real-IP'); } if (ip == null || ip.length() == 0 || 'unknown'.equalsIgnoreCase(ip)) { ip = request.getRemoteAddr(); } return ip.equals('0:0:0:0:0:0:0:1') ? '127.0.0.1' : ip; }}

public String getIpAddr(HttpServletRequest request){ String ipAddress = request.getHeader('x-forwarded-for'); if(ipAddress == null || ipAddress.length() == 0 || 'unknown'.equalsIgnoreCase(ipAddress)) { ipAddress = request.getHeader('Proxy-Client-IP'); } if(ipAddress == null || ipAddress.length() == 0 || 'unknown'.equalsIgnoreCase(ipAddress)) { ipAddress = request.getHeader('WL-Proxy-Client-IP'); } if(ipAddress == null || ipAddress.length() == 0 || 'unknown'.equalsIgnoreCase(ipAddress)) { ipAddress = request.getRemoteAddr(); if(ipAddress.equals('127.0.0.1') || ipAddress.equals('0:0:0:0:0:0:0:1')){ //根據(jù)網(wǎng)卡取本機(jī)配置的IP InetAddress inet=null; try { inet = InetAddress.getLocalHost(); } catch (UnknownHostException e) { e.printStackTrace(); } ipAddress= inet.getHostAddress(); } } //對于通過多個代理的情況,第一個IP為客戶端真實(shí)IP,多個IP按照’,’分割 if(ipAddress!=null && ipAddress.length()>15){ //'***.***.***.***'.length() = 15 if(ipAddress.indexOf(',')>0){ ipAddress = ipAddress.substring(0,ipAddress.indexOf(',')); } } return ipAddress; }

太平洋網(wǎng)絡(luò)IP地址查詢Web接口:http://whois.pconline.com.cn/

import java.io.BufferedReader;import java.io.DataOutputStream;import java.io.IOException;import java.io.InputStreamReader;import java.io.UnsupportedEncodingException;import java.net.HttpURLConnection;import java.net.URL;/** * 根據(jù)IP地址獲取詳細(xì)的地域信息 第一個方法是傳入ip獲取真實(shí)地址 最后一個方法是獲取訪問者真實(shí)ip 即使通過Nginx多層代理也可以獲取 */public class AddressUtils { public static String getAddresses(String content, String encodingString) throws UnsupportedEncodingException { // 這里調(diào)用pconline的接口 String urlStr = 'http://ip.taobao.com/service/getIpInfo.php'; // 從http://whois.pconline.com.cn取得IP所在的省市區(qū)信息 String returnStr = getResult(urlStr, content, encodingString); if (returnStr != null) { // 處理返回的省市區(qū)信息 System.out.println(returnStr); String[] temp = returnStr.split(','); if (temp.length < 3) { return '0';// 無效IP,局域網(wǎng)測試 } String country = ''; String area = ''; String region = ''; String city = ''; String county = ''; String isp = ''; for (int i = 0; i < temp.length; i++) { switch (i) { case 1: country = (temp[i].split(':'))[2].replaceAll(''', ''); country = decodeUnicode(country);// 國家 break;// case 3:// area = (temp[i].split(':'))[1].replaceAll(''', '');// area =decodeUnicode(area);//地區(qū)// break; case 5: region = (temp[i].split(':'))[1].replaceAll(''', ''); region = decodeUnicode(region);// 省份 break; case 7: city = (temp[i].split(':'))[1].replaceAll(''', ''); city = decodeUnicode(city);// 市區(qū) break; case 9: county = (temp[i].split(':'))[1].replaceAll(''', ''); county = decodeUnicode(county);// 地區(qū) break; case 11: isp = (temp[i].split(':'))[1].replaceAll(''', ''); isp = decodeUnicode(isp);// ISP公司 break; } } System.out.println(country + area + '=' + region + '=' + city + '=' + county + '=' + isp); StringBuffer sb = new StringBuffer(country).append(region).append(city).append(county).append(' ') .append(isp); return sb.toString(); } return null; } /** * @param urlStr 請求的地址 * @param content 請求的參數(shù) 格式為:name=xxx&pwd=xxx * @param encoding 服務(wù)器端請求編碼。如GBK,UTF-8等 * @return */ private static String getResult(String urlStr, String content, String encoding) { URL url = null; HttpURLConnection connection = null; try { url = new URL(urlStr); connection = (HttpURLConnection) url.openConnection();// 新建連接實(shí)例 connection.setConnectTimeout(3000);// 設(shè)置連接超時時間,單位毫秒 connection.setReadTimeout(3000);// 設(shè)置讀取數(shù)據(jù)超時時間,單位毫秒 connection.setDoOutput(true);// 是否打開輸出流 true|false connection.setDoInput(true);// 是否打開輸入流true|false connection.setRequestMethod('POST');// 提交方法POST|GET connection.setUseCaches(false);// 是否緩存true|false connection.connect();// 打開連接端口 DataOutputStream out = new DataOutputStream(connection.getOutputStream());// 打開輸出流往對端服務(wù)器寫數(shù)據(jù) out.writeBytes(content);// 寫數(shù)據(jù)(提交表單) out.flush();// 刷新 out.close();// 關(guān)閉輸出流 // 往對端寫完數(shù)據(jù)對端服務(wù)器返回?cái)?shù)據(jù),以BufferedReader流來讀取 BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream(), encoding)); StringBuffer buffer = new StringBuffer(); String line = ''; while ((line = reader.readLine()) != null) { buffer.append(line); } reader.close(); return buffer.toString(); } catch (IOException e) { e.printStackTrace(); } finally { if (connection != null) { connection.disconnect();// 關(guān)閉連接 } } return null; } /** * unicode 轉(zhuǎn)換成 中文 */ public static String decodeUnicode(String theString) { char aChar; int len = theString.length(); StringBuffer outBuffer = new StringBuffer(len); for (int x = 0; x < len;) { aChar = theString.charAt(x++); if (aChar == ’’) { aChar = theString.charAt(x++); if (aChar == ’u’) { int value = 0; for (int i = 0; i < 4; i++) { aChar = theString.charAt(x++); switch (aChar) { case ’0’: case ’1’: case ’2’: case ’3’: case ’4’: case ’5’: case ’6’: case ’7’: case ’8’: case ’9’: value = (value << 4) + aChar - ’0’; break; case ’a’: case ’b’: case ’c’: case ’d’: case ’e’: case ’f’: value = (value << 4) + 10 + aChar - ’a’; break; case ’A’: case ’B’: case ’C’: case ’D’: case ’E’: case ’F’: value = (value << 4) + 10 + aChar - ’A’; break; default: throw new IllegalArgumentException('Malformed encoding.'); } } outBuffer.append((char) value); } else { if (aChar == ’t’) { aChar = ’t’; } else if (aChar == ’r’) { aChar = ’r’; } else if (aChar == ’n’) { aChar = ’n’; } else if (aChar == ’f’) { aChar = ’f’; } outBuffer.append(aChar); } } else { outBuffer.append(aChar); } } return outBuffer.toString(); } // 測試 public static void main(String[] args) { AddressUtils addressUtils = new AddressUtils(); /** * 測試IP:111.121.72.101 中國貴州省貴陽市 電信 */ String ip = '111.121.72.101'; String address = ''; try { address = addressUtils.getAddresses('ip=' + ip, 'utf-8'); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } System.out.println(address);//中國貴州省貴陽市 電信 }}

到此這篇關(guān)于淺談使用Java-Web獲取客戶端真實(shí)IP的方法示例詳解的文章就介紹到這了,更多相關(guān)使用Java-Web獲取客戶端真實(shí)IP內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 滁州高低温冲击试验箱厂家_安徽高低温试验箱价格|安徽希尔伯特 | 美国PARKER齿轮泵,美国PARKER柱塞泵,美国PARKER叶片泵,美国PARKER电磁阀,美国PARKER比例阀-上海维特锐实业发展有限公司二部 | 软装设计-提供软装装饰和软装配饰及软装陈设的软装设计公司 | 专业生产动态配料系统_饲料配料系统_化肥配料系统等配料系统-郑州鑫晟重工机械有限公司 | 宜兴紫砂壶知识分享 - 宜兴壶人 医用空气消毒机-医用管路消毒机-工作服消毒柜-成都三康王 | 塑料熔指仪-塑料熔融指数仪-熔体流动速率试验机-广东宏拓仪器科技有限公司 | 钢托盘,钢制托盘,立库钢托盘,金属托盘制造商_南京飞天金属制品实业有限公司 | 热镀锌槽钢|角钢|工字钢|圆钢|H型钢|扁钢|花纹板-天津千百顺钢铁贸易有限公司 | 招商帮-一站式网络营销服务|搜索营销推广|信息流推广|短视视频营销推广|互联网整合营销|网络推广代运营|招商帮企业招商好帮手 | 成都思迪机电技术研究所-四川成都思迪编码器 | 钢绞线万能材料试验机-全自动恒应力两用机-混凝土恒应力压力试验机-北京科达京威科技发展有限公司 | 桐城新闻网—桐城市融媒体中心主办| 中药超微粉碎机(中药细胞级微粉碎)-百科| 海鲜池-专注海鲜鱼缸、移动海鲜缸、饭店鱼缸设计定做-日晟水族厂家 | 氟氨基酮、氯硝柳胺、2-氟苯甲酸、异香兰素-新晨化工 | 北钻固控设备|石油钻采设备-石油固控设备厂家| 帽子厂家_帽子工厂_帽子定做_义乌帽厂_帽厂_制帽厂_帽子厂_浙江高普制帽厂 | 心肺复苏模拟人|医学模型|急救护理模型|医学教学模型上海康人医学仪器设备有限公司 | 礼仪庆典公司,礼仪策划公司,庆典公司,演出公司,演艺公司,年会酒会,生日寿宴,动工仪式,开工仪式,奠基典礼,商务会议,竣工落成,乔迁揭牌,签约启动-东莞市开门红文化传媒有限公司 | 右手官网|右手工业设计|外观设计公司|工业设计公司|产品创新设计|医疗产品结构设计|EMC产品结构设计 | 家用净水器代理批发加盟_净水机招商代理_全屋净水器定制品牌_【劳伦斯官网】 | PSI渗透压仪,TPS酸度计,美国CHAI PCR仪,渗透压仪厂家_价格,微生物快速检测仪-华泰和合(北京)商贸有限公司 | 防水套管|柔性防水套管|伸缩器|伸缩接头|传力接头-河南伟创管道 防水套管_柔性防水套管_刚性防水套管-巩义市润达管道设备制造有限公司 | 酶联免疫分析仪-多管旋涡混合仪|混合器-莱普特科学仪器(北京)有限公司 | 粉末冶金-粉末冶金齿轮-粉末冶金零件厂家-东莞市正朗精密金属零件有限公司 | 安徽华耐泵阀有限公司-官方网站 安德建奇火花机-阿奇夏米尔慢走丝|高维|发那科-北京杰森柏汇 | 气动隔膜阀_气动隔膜阀厂家_卫生级隔膜阀价格_浙江浙控阀门有限公司 | 酸度计_PH计_特斯拉计-西安云仪| 全自动五线打端沾锡机,全自动裁线剥皮双头沾锡机,全自动尼龙扎带机-东莞市海文能机械设备有限公司 | 精密模具制造,注塑加工,吹塑和吹瓶加工,EPS泡沫包装生产 - 济南兴田塑胶有限公司 | 双齿辊破碎机-大型狼牙破碎机视频-对辊破碎机价格/型号图片-金联机械设备生产厂家 | 青岛侦探调查_青岛侦探事务所_青岛调查事务所_青岛婚外情取证-青岛狄仁杰国际侦探公司 | 空气净化器租赁,空气净化器出租,全国直租_奥司汀净化器租赁 | 手持气象站_便携式气象站_农业气象站_负氧离子监测站-山东万象环境 | 碳钢法兰厂家,非标法兰,定制异型,法兰生产厂家-河北九瑞管道 | 10吨无线拉力计-2吨拉力计价格-上海佳宜电子科技有限公司 | 消防泵-XBD单级卧式/立式消防泵-上海塑泉泵阀(集团)有限公司 | 重庆私家花园设计-别墅花园-庭院-景观设计-重庆彩木园林建设有限公司 | 微信聊天记录恢复_手机短信删除怎么恢复_通讯录恢复软件下载-快易数据恢复 | 浙江筋膜枪-按摩仪厂家-制造商-肩颈按摩仪哪家好-温州市合喜电子科技有限公司 | 警用|治安|保安|不锈钢岗亭-售货亭价格-垃圾分类亭-移动厕所厂家-苏州灿宇建材 |