目录
Hutool是一个小而全的Java工具类库,通过静态方法封装,降低相关API的学习成本,提高工作效率,使Java拥有函数式语言般的优雅,让Java语言也可以“甜甜的”。
Hutool中的工具方法来自每个用户的精雕细琢,它涵盖了Java开发底层代码中的方方面面,它既是大型项目开发中解决小问题的利器,也是小型项目中的效率担当;
Hutool是项目中“util”包友好的替代,它节省了开发人员对项目中公用类和公用工具方法的封装时间,使开发专注于业务,同时可以最大限度的避免封装不完善带来的bug。
Hutool = Hu + tool,是原公司项目底层代码剥离后的开源库,“Hu”是公司名称的表示,tool表示工具。Hutool谐音“糊涂”,一方面简洁易懂,一方面寓意“难得糊涂”。
Hutool的目标是使用一个工具方法代替一段复杂代码,从而最大限度的避免“复制粘贴”代码的问题,彻底改变我们写代码的方式。
以计算MD5为例:
Hutool的存在就是为了减少代码搜索成本,避免网络上参差不齐的代码出现导致的bug。
一个Java基础工具类,对文件、流、加密解密、转码、正则、线程、XML等JDK方法进行封装,组成各种Util工具类,同时提供以下组件:
| 模块 | 介绍 |
|---|---|
| hutool-aop | JDK动态代理封装,提供非IOC下的切面支持 |
| hutool-bloomFilter | 布隆过滤,提供一些Hash算法的布隆过滤 |
| hutool-cache | 简单缓存实现 |
| hutool-core | 核心,包括Bean操作、日期、各种Util等 |
| hutool-cron | 定时任务模块,提供类Crontab表达式的定时任务 |
| hutool-crypto | 加密解密模块,提供对称、非对称和摘要算法封装 |
| hutool-db | JDBC封装后的数据操作,基于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-json | JSON实现 |
| hutool-captcha | 图片验证码实现 |
| hutool-poi | 针对POI中Excel和Word的封装 |
| hutool-socket | 基于Java的NIO和AIO的Socket封装 |
| hutool-jwt | JSON Web Token (JWT)封装实现 |
官网:Hutool — 🍬A set of tools that keep Java sweet.
参考文档:简介 | Hutool
API文档:Document

Hutool-all是一个Hutool的集成打包产品,由于考虑到“懒人”用户及分不清各个模块作用的用户,“无脑”引入hutool-all模块是快速开始和深入应用的最佳方式。
起初Hutool只提供了两种引入方式:
引入hutool-all以便使用所有工具类功能
引入hutool-xxx单独模块使用
后来t-io的作者谭总提出是否可以引入一个bom包,一次性引入所有子模块,然后将不用的模块排除掉。起初我是排斥的,认为这种方式用处不大(其实是我不会写……)
再后来接触了Maven的这部分,于是有了hutool-bom模块!
当然这个模块的存在一直有争议,因为真正的bom包是一个模块管理包,正确的打开方式是可以引入,再引入需要的模块(只是不用重复版本号而已),Hutool中"排除"方式就变得非常异类,真是让人头大。
整个bom模块只由一个pom.xml组成,同时提供了dependencyManagement和dependencies两种声明。于是我们就可以针对不同需要完成引入。
如果你想像Spring-Boot一样引入Hutool,再由子模块决定用到哪些模块,你可以在父模块中加入:
cn.hutool
hutool-bom
${hutool.version}
pom
import
在子模块中就可以引入自己需要的模块了:
cn.hutool
hutool-http
PS:使用import的方式,只会引入hutool-bom内的dependencyManagement的配置,其它配置在这个引用方式下完全不起作用。
如果你引入的模块比较多,但是某几个模块没用,你可以:
cn.hutool
hutool-bom
${hutool.version}
pom
cn.hutool
hutool-system
PS:这个配置会传递依赖hutool-bom内所有dependencies的内容,当前hutool-bom内的dependencies全部设置了version,就意味着在maven resolve的时候hutool-bom内就算存在dependencyManagement也不会产生任何作用。
- <dependency>
- <groupId>cn.hutoolgroupId>
- <artifactId>hutool-allartifactId>
- <version>5.8.16version>
- dependency>
日期时间工具类,定义了一些常用的日期时间操作方法。
- //Date、long、Calendar之间的相互转换
- //当前时间
- Date date = DateUtil.date();
- //Calendar转Date
- date = DateUtil.date(Calendar.getInstance());
- //时间戳转Date
- date = DateUtil.date(System.currentTimeMillis());
- //自动识别格式转换
- String dateStr = "2017-03-01";
- date = DateUtil.parse(dateStr);
- //自定义格式化转换
- date = DateUtil.parse(dateStr, "yyyy-MM-dd");
- //格式化输出日期
- String format = DateUtil.format(date, "yyyy-MM-dd");
- //获得年的部分
- int year = DateUtil.year(date);
- //获得月份,从0开始计数
- int month = DateUtil.month(date);
- //获取某天的开始、结束时间
- Date beginOfDay = DateUtil.beginOfDay(date);
- Date endOfDay = DateUtil.endOfDay(date);
- //计算偏移后的日期时间
- Date newDate = DateUtil.offset(date, DateField.DAY_OF_MONTH, 2);
- //计算日期时间之间的偏移量
- long betweenDay = DateUtil.between(date, newDate, DateUnit.DAY);
字符串工具类,定义了一些常用的字符串操作方法。
- //判断是否为空字符串
- String str = "test";
- StrUtil.isEmpty(str);
- StrUtil.isNotEmpty(str);
- //去除字符串的前后缀
- StrUtil.removeSuffix("a.jpg", ".jpg");
- StrUtil.removePrefix("a.jpg", "a.");
- //格式化字符串
- String template = "这只是个占位符:{}";
- String str2 = StrUtil.format(template, "我是占位符");
- LOGGER.info("/strUtil format:{}", str2);
数字处理工具类,可用于各种类型数字的加减乘除操作及判断类型。
- double n1 = 1.234;
- double n2 = 1.234;
- double result;
- //对float、double、BigDecimal做加减乘除操作
- result = NumberUtil.add(n1, n2);
- result = NumberUtil.sub(n1, n2);
- result = NumberUtil.mul(n1, n2);
- result = NumberUtil.div(n1, n2);
- //保留两位小数
- BigDecimal roundNum = NumberUtil.round(n1, 2);
- String n3 = "1.234";
- //判断是否为数字、整数、浮点数
- NumberUtil.isNumber(n3);
- NumberUtil.isInteger(n3);
- NumberUtil.isDouble(n3);
- BeanUtil
- JavaBean的工具类,可用于Map与JavaBean对象的互相转换以及对象属性的拷贝。
-
- PmsBrand brand = new PmsBrand();
- brand.setId(1L);
- brand.setName("小米");
- brand.setShowStatus(0);
- //Bean转Map
- Map
map = BeanUtil.beanToMap(brand); - LOGGER.info("beanUtil bean to map:{}", map);
- //Map转Bean
- PmsBrand mapBrand = BeanUtil.mapToBean(map, PmsBrand.class, false);
- LOGGER.info("beanUtil map to bean:{}", mapBrand);
- //Bean属性拷贝
- PmsBrand copyBrand = new PmsBrand();
- BeanUtil.copyProperties(brand, copyBrand);
- LOGGER.info("beanUtil copy properties:{}", copyBrand);
Map操作工具类,可用于创建Map对象及判断Map是否为空。
- //将多个键值对加入到Map中
- Map
- {"key1", "value1"},
- {"key2", "value2"},
- {"key3", "value3"}
- });
- //判断Map是否为空
- MapUtil.isEmpty(map);
- MapUtil.isNotEmpty(map);
- AnnotationUtil
- 注解工具类,可用于获取注解与注解中指定的值。
-
- //获取指定类、方法、字段、构造器上的注解列表
- Annotation[] annotationList = AnnotationUtil.getAnnotations(HutoolController.class, false);
- LOGGER.info("annotationUtil annotations:{}", annotationList);
- //获取指定类型注解
- Api api = AnnotationUtil.getAnnotation(HutoolController.class, Api.class);
- LOGGER.info("annotationUtil api value:{}", api.description());
- //获取指定类型注解的值
- Object annotationValue = AnnotationUtil.getAnnotationValue(HutoolController.class, RequestMapping.class);
加密解密工具类,可用于MD5加密。
- //MD5加密
- String str = "123456";
- String md5Str = SecureUtil.md5(str);
- LOGGER.info("secureUtil md5:{}", md5Str);
验证码工具类,可用于生成图形验证码。
- //生成验证码图片
- LineCaptcha lineCaptcha = CaptchaUtil.createLineCaptcha(200, 100);
- try {
- request.getSession().setAttribute("CAPTCHA_KEY", lineCaptcha.getCode());
- response.setContentType("image/png");//告诉浏览器输出内容为图片
- response.setHeader("Pragma", "No-cache");//禁止浏览器缓存
- response.setHeader("Cache-Control", "no-cache");
- response.setDateHeader("Expire", 0);
- lineCaptcha.write(response.getOutputStream());
- } catch (IOException e) {
- e.printStackTrace();
- }
当然,Hutool的工具类中还有很多其他非常方便的方法,留着你自己去测试吧!使用Hutool工具,可以大大提高你的开发效率!
如果这篇文章对您有所帮助,或者有所启发的话,求一键三连:点赞、评论、收藏➕关注,您的支持是我坚持写作最大的动力。