Hutool

一组使 Java 保持良好状态的工具。(A set of tools that keep Java sweet.)

  • 所有者: chinabugotech/hutool
  • 平台: BSD, Cross-platform, Linux, Mac, Solaris, Windows
  • 许可证: Other
  • 分类:
  • 主题:
  • 喜欢:
    0
      比较:

Github星跟踪图


简介

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

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

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

Hutool名称的由来

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

Hutool如何改变我们的coding方式

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

以计算MD5为例:

  • 【以前】打开搜索引擎 -> 搜“Java MD5加密” -> 打开某篇博客-> 复制粘贴 -> 改改好用
  • 【现在】引入Hutool -> SecureUtil.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的封装, hutool-socket, 基于Java的NIO和AIO的Socket封装, 可以根据需求对每个模块单独引入,也可以通过引入hutool-all方式引入所有模块。


文档

中文文档
中文文档(备用)

参考API


安装

Maven

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

<dependency>
    <groupId>cn.hutool</groupId>
    <artifactId>hutool-all</artifactId>
    <version>5.1.3</version>
</dependency>

Gradle

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

非Maven项目

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

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

编译安装

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

./hutool.sh install

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


添砖加瓦

分支说明

Hutool的源码分为两个分支,功能如下:, 分支, 作用, -----------, ---------------------------------------------------------------, v5-master, 主分支,release版本使用的分支,与中央库提交的jar一致,不接收任何pr或修改, v5-dev, 开发分支,默认为下个版本的SNAPSHOT版本,接受修改或pr, ### 提供bug反馈或建议

提交问题反馈请说明正在使用的JDK版本呢、Hutool版本和相关依赖库版本。

贡献代码的步骤

  1. 在Gitee或者Github上fork项目到自己的repo
  2. 把fork过去的项目也就是你的项目clone到你的本地
  3. 修改代码(记得一定要修改v5-dev分支)
  4. commit后push到自己的库(v5-dev分支)
  5. 登录Gitee或Github在你首页可以看到一个 pull request 按钮,点击它,填写一些说明信息,然后提交即可。
  6. 等待作者合并

PR遵照的原则

Hutool欢迎任何人为Hutool添砖加瓦,贡献代码,不过作者是一个强迫症患者,为了照顾病人,需要提交的pr(pull request)符合一些规范,规范如下:

  1. 注释完备,尤其每个新增的方法应按照Java文档规范标明方法说明、参数说明、返回值说明等信息,必要时请添加单元测试,如果愿意,也可以加上你的大名。
  2. Hutool的缩进按照Eclipse(不要跟我说IDEA多好用,作者非常懒,学不会,IDEA真香,改了Eclipse快捷键后舒服多了)默认(tab)缩进,所以请遵守(不要和我争执空格与tab的问题,这是一个病人的习惯)。
  3. 新加的方法不要使用第三方库的方法,Hutool遵循无依赖原则(除非在extra模块中加方法工具)。
  4. 请pull request到v5-dev分支。Hutool在5.x版本后使用了新的分支:v5-master是主分支,表示已经发布中央库的版本,这个分支不允许pr,也不允许修改。

捐赠

如果你觉得Hutool不错,可以捐赠请作者吃包辣条~,在此表示感谢^_^。

点击以下链接,将页面拉到最下方点击“捐赠”即可。

前往捐赠

主要指标

概览
名称与所有者chinabugotech/hutool
主编程语言Java
编程语言Shell (语言数: 6)
平台BSD, Cross-platform, Linux, Mac, Solaris, Windows
许可证Other
所有者活动
创建于2014-04-13 07:23:51
推送于2025-08-25 08:58:44
最后一次提交
发布数152
最新版本名称5.8.39 (发布于 )
第一版名称4.4.2 (发布于 )
用户参与
星数30k
关注者数608
派生数7.7k
提交数5.6k
已启用问题?
问题数2988
打开的问题数4
拉请求数454
打开的拉请求数2
关闭的拉请求数513
项目设置
已启用Wiki?
已存档?
是复刻?
已锁定?
是镜像?
是私有?