當前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
Springboot添加白名单Ip
生活随笔
收集整理的這篇文章主要介紹了
Springboot添加白名单Ip
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
調(diào)用類:
在類的最上方添加讀取配置文件的語句
private static final String IP = ConfigUtil.readValue(“ipConfig.properties”, “ip”);
工具類:
package com.propertypay.utils;import java.util.ArrayList; import java.util.HashSet; import java.util.List; import java.util.Set; import java.util.regex.Pattern;/*** @ClassName:IPWhiteList* @Function: IP 白名單.* @Reason:關(guān)于IP白名單相關(guān).* @version*/ public class IPWhiteListUtil {// IP的正則private static Pattern pattern = Pattern.compile("(1\\d{1,2}|2[0-4]\\d|25[0-5]|\\d{1,2})\\."+ "(1\\d{1,2}|2[0-4]\\d|25[0-5]|\\d{1,2})\\."+ "(1\\d{1,2}|2[0-4]\\d|25[0-5]|\\d{1,2})\\."+ "(1\\d{1,2}|2[0-4]\\d|25[0-5]|\\d{1,2})");/**** getAvaliIpList:(根據(jù)IP白名單設(shè)置獲取可用的IP列表).** @date 2017-4-17 下午02:50:20* @return*/private static Set<String> getAvaliIpList(String allowIp) {Set<String> ipList = new HashSet<String>();for (String allow : allowIp.replaceAll("\\s", "").split(";")) {if (allow.indexOf("*") > -1) {String[] ips = allow.split("\\.");String[] from = new String[] { "0", "0", "0", "0" };String[] end = new String[] { "255", "255", "255", "255" };List<String> tem = new ArrayList<String>();for (int i = 0; i < ips.length; i++)if (ips[i].indexOf("*") > -1) {tem = complete(ips[i]);from[i] = null;end[i] = null;} else {from[i] = ips[i];end[i] = ips[i];}StringBuffer fromIP = new StringBuffer();StringBuffer endIP = new StringBuffer();for (int i = 0; i < 4; i++)if (from[i] != null) {fromIP.append(from[i]).append(".");endIP.append(end[i]).append(".");} else {fromIP.append("[*].");endIP.append("[*].");}fromIP.deleteCharAt(fromIP.length() - 1);endIP.deleteCharAt(endIP.length() - 1);for (String s : tem) {String ip = fromIP.toString().replace("[*]",s.split(";")[0])+ "-"+ endIP.toString().replace("[*]", s.split(";")[1]);if (validate(ip)) {ipList.add(ip);}}} else {if (validate(allow)) {ipList.add(allow);}}}return ipList;}private static Set<String> getAvaliIpList(Set<String> ipSet) {Set<String> ipList = new HashSet<String>();for (String allow : ipSet) {if (allow.indexOf("*") > -1) {String[] ips = allow.split("\\.");String[] from = new String[] { "0", "0", "0", "0" };String[] end = new String[] { "255", "255", "255", "255" };List<String> tem = new ArrayList<String>();for (int i = 0; i < ips.length; i++)if (ips[i].indexOf("*") > -1) {tem = complete(ips[i]);from[i] = null;end[i] = null;} else {from[i] = ips[i];end[i] = ips[i];}StringBuffer fromIP = new StringBuffer();StringBuffer endIP = new StringBuffer();for (int i = 0; i < 4; i++)if (from[i] != null) {fromIP.append(from[i]).append(".");endIP.append(end[i]).append(".");} else {fromIP.append("[*].");endIP.append("[*].");}fromIP.deleteCharAt(fromIP.length() - 1);endIP.deleteCharAt(endIP.length() - 1);for (String s : tem) {String ip = fromIP.toString().replace("[*]",s.split(";")[0])+ "-"+ endIP.toString().replace("[*]", s.split(";")[1]);if (validate(ip)) {ipList.add(ip);}}} else {if (validate(allow)) {ipList.add(allow);}}}return ipList;}/*** 對單個IP節(jié)點進行范圍限定** @param arg* @return 返回限定后的IP范圍,格式為List[10;19, 100;199]*/private static List<String> complete(String arg) {List<String> com = new ArrayList<String>();if (arg.length() == 1) {com.add("0;255");} else if (arg.length() == 2) {String s1 = complete(arg, 1);if (s1 != null)com.add(s1);String s2 = complete(arg, 2);if (s2 != null)com.add(s2);} else {String s1 = complete(arg, 1);if (s1 != null)com.add(s1);}return com;}private static String complete(String arg, int length) {String from = "";String end = "";if (length == 1) {from = arg.replace("*", "0");end = arg.replace("*", "9");} else {from = arg.replace("*", "00");end = arg.replace("*", "99");}if (Integer.valueOf(from) > 255)return null;if (Integer.valueOf(end) > 255)end = "255";return from + ";" + end;}/*** 在添加至白名單時進行格式校驗** @param ip* @return*/private static boolean validate(String ip) {for (String s : ip.split("-"))if (!pattern.matcher(s).matches()) {return false;}return true;}/**** checkLoginIP:(根據(jù)IP,及可用Ip列表來判斷ip是否包含在白名單之中).* @date 2017-4-17 下午03:01:03* @param ip* @param ipList* @return*/private static boolean checkLoginIP(String ip, Set<String> ipList) {if (ipList.contains(ip))return true;else {for (String allow : ipList) {if (allow.indexOf("-") > -1) {String[] from = allow.split("-")[0].split("\\.");String[] end = allow.split("-")[1].split("\\.");String[] tag = ip.split("\\.");// 對IP從左到右進行逐段匹配boolean check = true;for (int i = 0; i < 4; i++) {int s = Integer.valueOf(from[i]);int t = Integer.valueOf(tag[i]);int e = Integer.valueOf(end[i]);if (!(s <= t && t <= e)) {check = false;break;}}if (check) {return true;}}}}return false;}/**** checkLoginIP:(根據(jù)IP地址,及IP白名單設(shè)置規(guī)則判斷IP是否包含在白名單).* @param ip* @param ipWhiteConfig* @return*/public static boolean checkLoginIP(String ip,String ipWhiteConfig){Set<String> ipList = getAvaliIpList(ipWhiteConfig);return checkLoginIP(ip, ipList);}/**** ip在ipList中,則返回true* @param ip* @param ipList* @return* @see*/public static boolean checkIpList(String ip, List<String> ipList) {Set<String> ipSet = new HashSet<String>();for (String ipStr : ipList) {if (!ipStr.trim().startsWith("#")) {ipSet.add(ipStr.trim());}}ipSet = getAvaliIpList(ipSet);return checkLoginIP(ip, ipSet);}/**** ip在ip中,則返回true* @param ip* @param ipStr* @return* @see*/public static boolean checkIp(String ip, String ipStr) {Set<String> ipSet = new HashSet<String>();if (!ipStr.trim().startsWith("#")) {ipSet.add(ipStr.trim());}ipSet = getAvaliIpList(ipSet);return checkLoginIP(ip, ipSet);}public static void main(String[] args) {String ipWhilte = "192.168.1.1;" + //設(shè)置單個IP的白名單"192.168.2.*;" + //設(shè)置ip通配符,對一個ip段進行匹配"192.168.3.17-192.168.3.38"; //設(shè)置一個IP范圍boolean flag = checkLoginIP("192.168.2.2",ipWhilte);boolean flag2 = checkLoginIP("192.168.1.2",ipWhilte);boolean flag3 = checkLoginIP("192.168.3.16",ipWhilte);boolean flag4 = checkLoginIP("192.168.3.17",ipWhilte);System.out.println(flag); //trueSystem.out.println(flag2); //falseSystem.out.println(flag3); //falseSystem.out.println(flag4); //true}}IPUtil 工具類:
import javax.servlet.http.HttpServletRequest;public class IPUtil {/** * 獲取用戶真實IP地址,不使用request.getRemoteAddr()的原因是有可能用戶使用了代理軟件方式避免真實IP地址, * 可是,如果通過了多級反向代理的話,X-Forwarded-For的值并不止一個,而是一串IP值 * * @return ip*/public static String getIpAddr(HttpServletRequest request) {String ip = request.getHeader("x-forwarded-for"); if (ip != null && ip.length() != 0 && !"unknown".equalsIgnoreCase(ip)) { // 多次反向代理后會有多個ip值,第一個ip才是真實ipif( ip.indexOf(",")!=-1 ){ip = ip.split(",")[0];}} 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("WL-Proxy-Client-IP"); } if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) { ip = request.getHeader("HTTP_CLIENT_IP"); } if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) { ip = request.getHeader("HTTP_X_FORWARDED_FOR"); } 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; } }總結(jié)
以上是生活随笔為你收集整理的Springboot添加白名单Ip的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Linux 限制IP访问与白名单
- 下一篇: JSON树节点的增删查改