🍬小而全的Java工具类库,使Java拥有函数式语言般的优雅,让Java语言也可以“甜甜的”。
Go to file
2023-03-07 15:04:58 +08:00
.gitee PULL_REQUEST_TEMPLATE,增加:提交前自测 命令 2022-09-21 23:04:03 +08:00
.github fix template 2022-09-22 16:20:12 +08:00
bin prepare 5.8.15 2023-03-05 23:18:04 +08:00
docs prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-all prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-aop prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-bloomFilter prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-bom prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-cache prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-captcha prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-core prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-cron prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-crypto prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-db prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-dfa prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-extra prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-http prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-json prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-jwt prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-log prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-poi prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-script prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-setting prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-socket prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool-system prepare 5.8.15 2023-03-05 23:18:04 +08:00
.editorconfig fix config 2021-01-20 17:44:09 +08:00
.gitignore add MetroHash 2022-02-11 17:35:05 +08:00
.travis.yml change line sep 2021-01-20 17:10:45 +08:00
CHANGELOG_5.0-5.7.md add ansi 2022-04-27 13:49:31 +08:00
CHANGELOG.md prepare 5.8.15 2023-03-05 23:18:04 +08:00
hutool.sh clean history 2019-08-14 10:02:32 +08:00
LICENSE change line sep 2021-01-20 17:10:45 +08:00
pom.xml fix pom 2023-03-07 15:04:58 +08:00
README-EN.md prepare 5.8.15 2023-03-05 23:18:04 +08:00
README.md prepare 5.8.15 2023-03-05 23:18:04 +08:00
SECURITY.md add SECURITY 2021-10-13 01:27:21 +08:00

🍬A set of tools that keep Java sweet.

👉 https://hutool.cn/ 👈

star github star



🌎English Documentation


📚简介

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和Word的封装
hutool-socket 基于Java的NIO和AIO的Socket封装
hutool-jwt JSON Web Token (JWT)封装实现

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


📝文档

📘中文文档

📘中文备用文档

📙参考API

🎬视频介绍


🪙支持Hutool

💳捐赠

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

Gitee上捐赠

捐赠给Dromara组织

👕周边商店

你也可以通过购买Hutool的周边商品来支持Hutool维护哦

我们提供了印有Hutool Logo的周边商品欢迎点击购买支持

👉 Hutool 周边商店 👈


📦安装

🍊Maven

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

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

🍐Gradle

implementation 'cn.hutool:hutool-all:5.8.15.M1'

📥下载jar

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

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

🚽编译安装

访问Hutool的Gitee主页https://gitee.com/dromara/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添砖加瓦贡献代码不过维护者是一个强迫症患者为了照顾病人需要提交的prpull 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也不允许修改。
  5. 我们如果关闭了你的issue或pr请不要诧异这是我们保持问题处理整洁的一种方式你依旧可以继续讨论当有讨论结果时我们会重新打开。

Star Hutool

Stargazers over time

📌 知识星球