热门标签 | HotTags
当前位置:  开发笔记 > 开发工具 > 正文

Java判断字符串是否为IP地址的方法

这篇文章主要为大家详细介绍了Java判断字符串是否为IP地址的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

Java 判断字符串是否为IP地址,供大家参考,具体内容如下

1、代码

主要就是这么几个条件

  • 非空
  • 长度符合 0.0.0.0 - 255.255.255.255
  • 包含分隔符 且 个数正确
  • 四个全部是数字,且都在合理的范围内
 /**
 * 判断某个字符串是否是一个 IP 地址
 *
 * @param str 字符串
 */
 public static boolean isIpStr(String str) {
 // 非空
 // boolean notBlank = StringUtils.isNotBlank(str);
 // 长度符合 0.0.0.0 - 255.255.255.255
 // boolean length = CommonUtils.isNumberBetween(str.length(),7,15);

 if (StringUtils.isNotBlank(str) && CommonUtils.isNumberBetween(str.length(), 7, 15)) {
  String regex = ".";
  // 包含分隔符 且 个数正确
  if (str.contains(regex) && str.split(regex).length == 4) {
  boolean legalNumber = true;
  // 四个全部是数字,且都在合理的范围内
  for (String obj : Lists.newArrayList(str.split(regex))) {
   if (NumberUtils.isDigit(obj)) {
   Integer value = Integer.parseInt(obj);
   legalNumber = CommonUtils.isNumberBetween(value, 0, 255);
   } else {
   // 任意一个不是数字,不合法
   legalNumber = false;
   break;
   }
  }
  return legalNumber;
  }
 }
 return false;
}

2、CommonUtils 工具类

package cn.zjcs.common.util;

import cn.hutool.core.util.ReUtil;
import lombok.AccessLevel;
import lombok.Getter;
import lombok.NoArgsConstructor;

import java.math.BigDecimal;
import java.math.RoundingMode;

/**
 * @author Created by 谭健 on 2019/6/11. 星期二. 15:20.
 * © All Rights Reserved.
 */

@NoArgsConstructor(access = AccessLevel.PRIVATE)
public class CommonUtils {


 /**
 * 是否为 null
 *
 * @param o
 * @return null返回 true
 */
 public static boolean isNull(Object o) {
 return o == null;
 }

 /**
 * 是否不为 null
 *
 * @param o
 * @return 不为 null 返回 true
 */
 public static boolean isNotNull(Object o) {
 return !isNull(o);
 }

 /**
 * 是否是0 ,
 *
 * @param bigDecimal
 * @return 0 返回true
 */
 public static boolean isZeroDecimal(BigDecimal bigDecimal) {
 return isNotNull(bigDecimal) && bigDecimal.compareTo(BigDecimal.ZERO) == 0;
 }

 /**
 * 是否不是 0
 *
 * @param bigDecimal
 * @return 不是0 返回true
 */
 public static boolean isNotZeroDecimal(BigDecimal bigDecimal) {
 return !isZeroDecimal(bigDecimal);
 }

 /**
 * 是否是 1
 *
 * @param bigDecimal
 * @return 是 1 返回true
 */
 public static boolean isOneDecimal(BigDecimal bigDecimal) {
 return isNotNull(bigDecimal) && bigDecimal.compareTo(BigDecimal.ONE) == 0;
 }

 /**
 * 是否不是 1
 *
 * @param bigDecimal
 * @return 不是 1 返回true
 */
 public static boolean isNotOneDecimal(BigDecimal bigDecimal) {
 return bigDecimal.compareTo(BigDecimal.ONE) != 0;
 }

 /**
 * 是否是 0 long
 *
 * @param l
 * @return 是 0 long 返回 true
 */
 public static boolean isZeroLong(Long l) {
 return l != null && l.equals(0L);
 }

 /**
 * 是否不是 0 long
 *
 * @param l
 * @return 不是 0 long 返回 true
 */
 public static boolean isNotZeroLong(Long l) {
 return !isZeroLong(l);
 }

 /**
 * 是否是 0 int
 *
 * @param l
 * @return 是 0 int 返回 true
 */
 public static boolean isZeroInt(Integer l) {
 return l != null && l.equals(0);
 }

 /**
 * 是否不是 0 int
 *
 * @param l
 * @return 不是 0 int 返回 true
 */
 public static boolean isNotZeroInt(Integer l) {
 return !isZeroInt(l);
 }

 /**
 * 两个 decimal 是否相等
 *
 * @param i
 * @param j
 * @return 相等返回 true
 */
 public static boolean isSameDecimal(BigDecimal i, BigDecimal j) {
 return i.compareTo(j) == 0;
 }

 /**
 * 第一个 decimal 是否大于 第二个 decimal
 *
 * @param i
 * @param j
 * @return 大于 返回true
 */
 public static boolean isDecimalGt(BigDecimal i, BigDecimal j) {
 return i.compareTo(j) > 0;
 }

 /**
 * 第一个 decimal 是否小于 第二个 decimal
 *
 * @param i
 * @param j
 * @return 小于 返回true
 */
 public static boolean isDecimalLt(BigDecimal i, BigDecimal j) {
 return i.compareTo(j) <0;
 }

 /**
 * 特殊字符串处理
 *
 * @param character
 * @return
 */
 public static String replaceSpecialCharacter(String character) {
 String regEx = "[`~!@#$%^&*()+=|{}':;',\\[\\].<>/&#63;~!@#¥%……&*()——+|{}【】‘;:”“'。,、?]";
 return ReUtil.replaceAll(character, regEx, "");
 }

 /**
 * 数据分比切割
 * 

* 比如 p 为 2,要做千分切割,则 h 值为 "1000.00" * 得到值为 0.002 * * @param p 输入值 * @param h 切割值 * @return 切割后的值 */ public static BigDecimal percentFormat(Integer p, String h) { return new BigDecimal(String.valueOf(p)).divide(new BigDecimal(h), 4, RoundingMode.HALF_UP).setScale(4, BigDecimal.ROUND_HALF_UP); } public static boolean orEq(Object... o) { if (o.length <2) { throw new NullPointerException("长度不足"); } Object o1 = o[0]; for (int i = 1; i = min.longValue() && number.longValue() <= max.longValue(); } /** * 标准数学计算 */ @NoArgsConstructor(access = AccessLevel.PRIVATE) public static class Math { /** * 精确的表示分数的数学计算,因为使用double 等会丢失精度 */ @SuppressWarnings("rawtypes") @Getter public static class Fraction extends Number implements Comparable { private static final long serialVersiOnUID= 2330398718018182597L; /** * 定义分子 */ private long numerator = 0; /** * 定义分母 */ private long denominator = 1; public Fraction() { this(0, 1); } public Fraction(long numerator, long denominator) { long gcd = gcd(numerator, denominator); this.numerator = ((denominator > 0) &#63; 1 : -1) * numerator / gcd; this.denominator = java.lang.Math.abs(denominator) / gcd; } /** * 求最大公约数 */ private long gcd(long f, long s) { long fAbs = java.lang.Math.abs(f); long sAbs = java.lang.Math.abs(s); // 学术名称 Gcd int _Gcd = 1; // 欧几里德算法 for (int i = 1; i <= fAbs && i <= sAbs; i++) { if (fAbs % i == 0 && sAbs % i == 0) { _Gcd = i; } } return _Gcd; } /** * 分数的加法 * */ public Fraction add(Fraction secondRational) { long n = numerator * secondRational.getDenominator() + denominator * secondRational.getNumerator(); long d = denominator * secondRational.getDenominator(); return new Fraction(n, d); } /** * 分数的减法 * */ public Fraction subtract(Fraction secondRational) { long n = numerator * secondRational.getDenominator() - denominator * secondRational.getNumerator(); long d = denominator * secondRational.getDenominator(); return new Fraction(n, d); } /** * 分数乘法 * */ public Fraction mulitiply(Fraction secondRational) { long n = numerator * secondRational.getNumerator(); long d = denominator * secondRational.getDenominator(); return new Fraction(n, d); } /** * 分数除法 * */ public Fraction divide(Fraction secondRational) { long n = numerator * secondRational.getDenominator(); long d = denominator * secondRational.numerator; return new Fraction(n, d); } @Override public String toString() { if (denominator == 1) { return numerator + ""; } else { return numerator + "/" + denominator; } } @SuppressWarnings("all") @Override public boolean equals(Object parm1) { return (this.subtract((Fraction) (parm1))).getNumerator() == 0; } @Override public int compareTo(Object o) { if ((this.subtract((Fraction) o)).getNumerator() > 0) { return 1; } else if ((this.subtract((Fraction) o)).getNumerator() > 0) { return -1; } else { return 0; } } @Override public double doubleValue() { return numerator * 1.0 / denominator; } @Override public float floatValue() { return (float) doubleValue(); } @Override public int intValue() { return (int) doubleValue(); } @Override public long longValue() { return (long) doubleValue(); } } /** * @param dividend 被除数 * @param divisor 除数 * @param accuracy 精度 */ public static BigDecimal divide(BigDecimal dividend, BigDecimal divisor, int accuracy) { // 0 除以任何数 = 无穷大,任何数除以 0 无法除,都会抛出错误 if (isZeroDecimal(divisor) || isZeroDecimal(dividend)) { return BigDecimal.ZERO; } return dividend.divide(divisor, 16, RoundingMode.HALF_UP).setScale(accuracy, RoundingMode.HALF_UP); } /** * @param f . * @param s . * @param accuracy 精度 */ public static BigDecimal multiply(BigDecimal f, BigDecimal s, int accuracy) { // 0 * 任何数 = 0 if (isZeroDecimal(f) || isZeroDecimal(s)) { return BigDecimal.ZERO; } return f.multiply(s).setScale(accuracy, RoundingMode.HALF_UP); } /** * 开多次方根 * */ public static BigDecimal pow(BigDecimal f, BigDecimal s) { // 防止出现 Infinity 的情况 if (isZeroDecimal(f) && isDecimalLt(s, BigDecimal.ZERO)) { return BigDecimal.ZERO; } return new BigDecimal(String.valueOf(java.lang.Math.pow(f.doubleValue(), s.doubleValue()))); } /** * 获取分数值 * */ public static BigDecimal fraction(Fraction f) { long denominator = f.getDenominator(); long numerator = f.getNumerator(); return divide(new BigDecimal(String.valueOf(numerator)), new BigDecimal(String.valueOf(denominator)), 16); } } }

3、NumberUtils 工具类

package cn.zjcs.common.util;

import lombok.AccessLevel;
import lombok.NoArgsConstructor;

import java.math.BigDecimal;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

/**
 * @author ..
 */
@NoArgsConstructor(access = AccessLevel.PRIVATE)
public class NumberUtils {

 private static final Pattern DIGIT_PATTERN = Pattern.compile("[0-9]*");

 /**
 * 判断 某个 decimal 是否等于 0
 *
 * @param decimal BigDecimal 数字
 * @return 等于0 返回 true
 */
 public static boolean isZeroDecimal(BigDecimal decimal) {
 return decimal == null || decimal.compareTo(BigDecimal.ZERO) == 0;
 }

 /**
 * 判断 某个 decimal 是否不等于 0
 *
 * @param decimal BigDecimal 数字
 * @return 不等于0 返回 true
 */
 public static boolean isNotZeroDecimal(BigDecimal decimal) {
 return decimal != null && decimal.compareTo(BigDecimal.ZERO) != 0;
 }

 /**
 * 判断一个字符串是否是数字
 *
 * @param var 字符串
 * @return 是数字返回 true
 */
 public static boolean isDigit(String var) {
 Matcher isNum = DIGIT_PATTERN.matcher(var);
 return isNum.matches();
 }

 public static boolean isEmptyNumber(Number number) {
 return number == null
   || number.intValue() == 0
   || number.longValue() == 0
   || number.doubleValue() == 0.00
   || number.byteValue() == 0
   || number.floatValue() == 0.0
   || number.shortValue() == 0;
 }

 public static boolean isNotEmptyNumber(Number number) {
 return !isEmptyNumber(number);
 }

 public static boolean isNotZeroLong(Long something) {
 if (something == null) {
  return false;
 }
 return !something.equals(0L);
 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • 在处理大数相加的问题时,有许多方法可以借鉴。本文介绍了两种不同的函数式编程方法:一种是从网络上找到的经典实现,另一种是作者自行设计的创新方案。通过函数式编程的方式重新实现了这两种方法,其中经典实现简洁明了,而创新方案则在性能和可读性方面有所提升。这些方法不仅适用于大数相加,还可以扩展应用于其他数值计算场景。 ... [详细]
  • 本文介绍了UUID(通用唯一标识符)的概念及其在JavaScript中生成Java兼容UUID的代码实现与优化技巧。UUID是一个128位的唯一标识符,广泛应用于分布式系统中以确保唯一性。文章详细探讨了如何利用JavaScript生成符合Java标准的UUID,并提供了多种优化方法,以提高生成效率和兼容性。 ... [详细]
  • Golomb 编码是一种高效的变长编码技术,专门用于整数的压缩。该方法通过预定义的参数 \( M \) 将输入整数分解为商 \( q \) 和余数 \( r \) 两部分。具体而言,输入整数除以 \( M \) 得到商 \( q \) 和余数 \( r \),其中商 \( q \) 采用一元编码表示,而余数 \( r \) 则使用二进制编码。这种编码方式在数据压缩和信息传输中具有显著的优势,特别是在处理具有特定概率分布的数据时表现出色。 ... [详细]
  • 在深入研究 React 项目的过程中,特别是在探索 react-router 源码时,我发现了其中蕴含的中间件概念。这激发了我对中间件的进一步思考与整理。本文将详细探讨 Redux 中间件的原理及其在实际项目中的应用,帮助读者更好地理解和使用这一强大工具。通过具体示例和代码解析,我们将揭示中间件如何提升应用的状态管理和异步操作处理能力。 ... [详细]
  • 利用CSS技术实现文本的上标和下标效果
    通过运用CSS中的`vertical-align`属性,可以实现文本的上标和下标效果。该属性通常用于调整行内元素的垂直对齐方式,例如在化学公式中表示二氧化碳(CO₂)时,可以将数字“2”设置为下标。此外,`vertical-align`还支持多种值,如`super`、`sub`等,以满足不同的排版需求。 ... [详细]
  • 易语言程序加密的基本原则涉及多种技术和策略。早期的加密方法主要是在软盘上创建非标准磁道,并在这些磁道中存储关键数据,例如解密密钥等。现代加密技术则更加注重算法的安全性和数据的完整性,以确保程序在运行过程中不被轻易破解。 ... [详细]
  • 本文深入探讨了B树、B+树和B*树的数据结构及其应用场景。B树是一种自平衡的搜索树,通过中序遍历可以确保数据的有序性。B+树在B树的基础上进行了优化,所有叶子节点都包含关键字,并且通过指针相连,便于区间查询。B*树则进一步改进了B+树,通过增加节点的填充因子来减少树的高度,提高磁盘读写的效率。这些数据结构广泛应用于数据库系统和文件索引中,以实现高效的数据存储和检索。 ... [详细]
  • 本文探讨了如何利用Java 8 Stream API 对数组进行高效排序和筛选处理。具体而言,通过 `stream()` 方法将 `listResult` 转换为流,然后使用 `sorted(Comparator.comparing())` 方法按伴随度进行降序排序,并最终收集结果。此外,还介绍了如何结合过滤条件进一步优化数据处理流程,提升代码的可读性和执行效率。 ... [详细]
  • HBase Java API 进阶:过滤器详解与应用实例
    本文详细探讨了HBase 1.2.6版本中Java API的高级应用,重点介绍了过滤器的使用方法和实际案例。首先,文章对几种常见的HBase过滤器进行了概述,包括列前缀过滤器(ColumnPrefixFilter)和时间戳过滤器(TimestampsFilter)。此外,还详细讲解了分页过滤器(PageFilter)的实现原理及其在大数据查询中的应用场景。通过具体的代码示例,读者可以更好地理解和掌握这些过滤器的使用技巧,从而提高数据处理的效率和灵活性。 ... [详细]
  • 妻子指导我深入学习机器算法 ... [详细]
  • 如何快速掌握日柱推算技巧?解读大运、小运、流年与命宫的精准方法
    大运是指人生各阶段的运势变化,通过命理学分析,可以预测个人在不同时间段的吉凶祸福。本文将详细介绍如何快速掌握日柱推算技巧,解读大运、小运、流年与命宫的精准方法,帮助读者更好地理解并运用这些命理知识,从而在关键时刻做出明智决策。 ... [详细]
  • 哈希表(Hash Table)是一种高效的查找算法,与传统的链表和树结构相比,其在查找过程中无需进行逐个元素的比较。本文将深入探讨哈希表的基本原理、应用场景以及优化策略,帮助读者全面理解其在实际开发中的优势和局限性。通过实例分析和代码示例,我们将展示如何有效利用哈希表提高数据处理效率,并解决常见的冲突问题。 ... [详细]
  • 题目要求在给定的 m×n 矩阵中,计算并返回所有完全由 1 组成的正方形子矩阵的数量。矩阵中的每个元素只能是 0 或 1。通过动态规划的方法,可以高效地解决这一问题。示例中,输入矩阵包含多个由 1 组成的正方形子矩阵,需要统计这些子矩阵的总数。 ... [详细]
  • 在 Python 中,列表(list)是一种内置的数据类型,属于有序且可变的集合,支持随时添加或删除元素。此外,Python 还提供了多种独特的数据结构,如字典(dict)、集合(set)和元组(tuple),每种数据结构都有其特定的应用场景和优势。了解这些数值类型和数据结构对于高效编程至关重要。 ... [详细]
  • 深入探讨:Java 8 中 HashMap 链表为何选择红黑树而非 AVL 树
    深入探讨:Java 8 中 HashMap 链表为何选择红黑树而非 AVL 树 ... [详细]
author-avatar
漫天星雨2000
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有