开发工具篇第十一讲:常用开发库 - Hutool包
创始人
2025-06-01 17:02:30

开发工具篇第十一讲:常用开发库 - Hutool包

本文是开发工具篇第十一讲:常用开发库 - Hutool包。Hutool作为后起之秀,功能上也比较全。但是要注意一点,它的开源协议是:中国第一个开源协议木兰宽松许可证, 第1版,对此在商业项目中需要谨慎些,在个人项目无所谓。

文章目录

  • 开发工具篇第十一讲:常用开发库 - Hutool包
    • 1、简介
      • 1.1、Hutool名称的由来
      • 1.2、Hutool如何改变我们的coding方式
    • 2、包含组件
    • 3、文档
    • 4、安装
      • 4.1、Maven
      • 4.2、Gradle
      • 4.3、非Maven项目
      • 4.4、编译安装
    • 5、Hutool在项目中的使用

1、简介

Hutool是一个小而全的Java工具类库,通过静态方法封装,降低相关API的学习成本,提高工作效率,使Java拥有函数式语言般的优雅,让Java语言也可以“甜甜的”。

Hutool中的工具方法来自于每个用户的精雕细琢,它涵盖了Java开发底层代码中的方方面面,它既是大型项目开发中解决小问题的利器,也是小型项目中的效率担当;

Hutool是项目中“util”包友好的替代,它节省了开发人员对项目中公用类和公用工具方法的封装时间,使开发专注于业务,同时可以最大限度的避免封装不完善带来的bug。

1.1、Hutool名称的由来

Hutool = Hu + tool,是原公司项目底层代码剥离后的开源库,“Hu”是公司名称的表示,tool表示工具。Hutool谐音“糊涂”,一方面简洁易懂,一方面寓意“难得糊涂”。

1.2、Hutool如何改变我们的coding方式

Hutool的目标是使用一个工具方法代替一段复杂代码,从而最大限度的避免“复制粘贴”代码的问题,彻底改变我们写代码的方式。

以计算MD5为例:

  • 【以前】打开搜索引擎 -> 搜“Java MD5加密” -> 打开某篇博客-> 复制粘贴 -> 改改好用
  • 【现在】引入Hutool -> SecureUtil.md5()

Hutool的存在就是为了减少代码搜索成本,避免网络上参差不齐的代码出现导致的bug。

2、包含组件

一个Java基础工具类,对文件、流、加密解密、转码、正则、线程、XML等JDK方法进行封装,组成各种Util工具类,同时提供以下组件:

模块介绍
hutool-aopJDK动态代理封装,提供非IOC下的切面支持
hutool-bloomFilter布隆过滤,提供一些Hash算法的布隆过滤
hutool-cache简单缓存实现
hutool-core核心,包括Bean操作、日期、各种Util等
hutool-cron定时任务模块,提供类Crontab表达式的定时任务
hutool-crypto加密解密模块,提供对称、非对称和摘要算法封装
hutool-dbJDBC封装后的数据操作,基于ActiveRecord思想
hutool-dfa基于DFA模型的多关键字查找
hutool-extra扩展模块,对第三方封装(模板引擎、邮件、Servlet、二维码、Emoji、FTP、分词等)
hutool-http基于HttpUrlConnection的Http客户端封装
hutool-log自动识别日志实现的日志门面
hutool-script脚本执行封装,例如Javascript
hutool-setting功能更强大的Setting配置文件和Properties封装
hutool-system系统参数调用封装(JVM信息等)
hutool-jsonJSON实现
hutool-captcha图片验证码实现
hutool-poi针对POI中Excel的封装
hutool-socket基于Java的NIO和AIO的Socket封装

可以根据需求对每个模块单独引入,也可以通过引入hutool-all方式引入所有模块。

3、文档

  • 中文文档 看这里
  • 中文文档(备用)
  • 参考API

4、安装

4.1、Maven

在项目的pom.xml的dependencies中加入以下内容:

cn.hutoolhutool-all5.7.13

4.2、Gradle

compile 'cn.hutool:hutool-all:5.7.13'

4.3、非Maven项目

点击以下任一链接,下载hutool-all-X.X.X.jar即可:

  • Maven中央库1
  • Maven中央库2

注意 Hutool 5.x支持JDK8+,对Android平台没有测试,不能保证所有工具类获工具方法可用。 如果你的项目使用JDK7,请使用Hutool 4.x版本

4.4、编译安装

访问Hutool的码云主页:https://gitee.com/loolly/hutool 下载整个项目源码(v5-master或v5-dev分支都可)然后进入Hutool项目目录执行:

./hutool.sh install

然后就可以使用Maven引入了。

5、Hutool在项目中的使用

CollStreamUtil、CollectionUtil 集合工具类

//场景1:按某字段进行分组并转换为map
Map> map = CollStreamUtil.groupByKey(list, InfoDO::getNo);//场景2:将对象集合映射为字段集合
List listB = CollStreamUtil.toList(list, InfoDO::getId);
Set sets = CollStreamUtil.toSet(list, InfoDO::getId);//场景3:集合转换为map
Map map = CollStreamUtil.toMap(list, BillDO::getId, temp -> temp);
Map map = CollStreamUtil.toIdentityMap(list, DO::getId);

DateField、DateTime、DateUtil(时间工具类)

// 定义
public enum DateField {ERA(0),YEAR(1),MONTH(2),WEEK_OF_YEAR(3),WEEK_OF_MONTH(4),DAY_OF_MONTH(5),DAY_OF_YEAR(6),DAY_OF_WEEK(7),DAY_OF_WEEK_IN_MONTH(8),AM_PM(9),HOUR(10),HOUR_OF_DAY(11),MINUTE(12),SECOND(13),MILLISECOND(14);
}public class DateTime extends Date {private static boolean useJdkToStringStyle = false;/*** 设置全局的,是否使用{@link Date}默认的toString()格式
* 如果为{@code true},则调用toString()时返回"EEE MMM dd HH:mm:ss zzz yyyy"格式,
* 如果为{@code false},则返回"yyyy-MM-dd HH:mm:ss",
* 默认为{@code false}** @param customUseJdkToStringStyle 是否使用{@link Date}默认的toString()格式* @since 5.7.21*/public static void setUseJdkToStringStyle(boolean customUseJdkToStringStyle){useJdkToStringStyle = customUseJdkToStringStyle;}/*** 是否可变对象*/private boolean mutable = true;/*** 一周的第一天,默认是周一, 在设置或获得 WEEK_OF_MONTH 或 WEEK_OF_YEAR 字段时,Calendar 必须确定一个月或一年的第一个星期,以此作为参考点。*/private Week firstDayOfWeek = Week.MONDAY;/*** 时区*/private TimeZone timeZone;/*** 第一周最少天数*/private int minimalDaysInFirstWeek; }// 使用if (Objects.nonNull(VO.getSettlementDay()) && Objects.nonNull(orderDO.getEtd())) {DateTime dateTime = new DateTime(orderDO.getEtd());dateTime.offset(DateField.MONTH, 1);dateTime.setField(DateField.DAY_OF_MONTH, enterpriseVO.getSettlementDay());return dateTime.toJdkDate();}

NumberUtil 数字工具类

// 场景1 小于
if (NumberUtil.isLess(param.getRate(), BigDecimal.valueOf(0.0001))) {throw new FinanceException(ServiceResponseCode.PARAM_ILLEGAL_ERROR);
}// 场景2 指定数值格式
public static String formatBigDecimal(BigDecimal value) {return Objects.nonNull(value) ? NumberUtil.decimalFormat("0.00", value) : "-";
}

BeanUtil bean转换

// 场景1:bean转mapmap = CollStreamUtil.toList(list, BeanUtil::beanToMap).stream().map(temp -> {Map map = new HashMap<>();map.put("id", temp.get("id"));map.put("name", map1.get((Long) temp.get("id")).getName());map.put("amount", temp.get("amount"));map.put("state", temp.get("state"));map.put("teamId", temp.get("teamId"));return map;}).collect(Collectors.toSet());
// 场景2:bean拷贝  底层使用的反射
OrderDO copy = BeanUtils.copy(infoVo, OrderDO.class);

IoUtil工具类

ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
xssfWorkbook.write(byteArrayOutputStream);
ossService.upload(filePath, IoUtil.toStream(byteArrayOutputStream));

相关内容

热门资讯

经验总结“欢乐龙城9.到底是有... 您好:欢乐龙城9.这款游戏可以开挂,确实是有挂的,需要了解加客服微信【3636476】很多玩家在这款...
「科技热点」“风风棋牌真的有挂... 您好:风风棋牌这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9158489】很多玩家在这款游戏...
分享实测“中至赣州麻将是不是有... 您好:中至赣州麻将这款游戏可以开挂,确实是有挂的,需要软件加微信【69174242】,很多玩家在中至...
实测普及“玄武大厅 有没有挂的... 您好:玄武大厅这款游戏可以开挂,确实是有挂的,需要软件加微信【3398215】很多玩家在这款游戏中打...
科普实测“途游四川麻将是不是有... 您好:途游四川麻将这款游戏可以开挂,确实是有挂的,需要软件加微信【8700483】,很多玩家在途游四...