🍬小而全的Java工具类库,使Java拥有函数式语言般的优雅,让Java语言也可以“甜甜的”。
Go to file
2025-03-25 10:32:56 +00:00
.gitee fix code 2023-03-13 11:41:20 +08:00
.github update copyright 2025-01-01 23:44:09 +08:00
bin prepare M21 2025-02-18 09:18:07 +08:00
docs add deply doc 2025-02-25 18:00:25 +08:00
hutool-all prepare M21 2025-02-18 09:18:07 +08:00
hutool-bom prepare M21 2025-02-18 09:18:07 +08:00
hutool-core 布尔枚举新增大写 2025-03-25 18:22:03 +08:00
hutool-cron fix comment 2025-02-18 15:13:08 +08:00
hutool-crypto fix comment 2025-03-19 12:50:37 +08:00
hutool-db 增加GoldenDB识别(pr#3886@Github) 2025-03-07 10:56:46 +08:00
hutool-extra add methods 2025-02-27 08:17:59 +08:00
hutool-http 修复HttpUtil.normalizeParams规则问题(issue#IBQIYQ@Gitee) 2025-03-07 09:46:44 +08:00
hutool-jmh update copyright 2025-01-01 23:44:09 +08:00
hutool-json 修复JsonUtil.toBean泛型数组类型丢失问题(pr#3876@Github) 2025-03-03 12:05:32 +08:00
hutool-log prepare M21 2025-02-18 09:18:07 +08:00
hutool-poi prepare M21 2025-02-18 09:18:07 +08:00
hutool-setting 修复SettingLoaderload未抛出异常导致配置文件无法正常遍历的问题(pr#3868@Github) 2025-02-24 10:25:06 +08:00
hutool-socket prepare M21 2025-02-18 09:18:07 +08:00
hutool-swing prepare M21 2025-02-18 09:18:07 +08:00
.editorconfig fix config 2021-01-20 17:44:09 +08:00
.gitignore add ignore 2025-02-14 17:44:06 +08:00
.travis.yml fix code 2023-04-23 00:05:39 +08:00
CHANGELOG.md fix issue#3765 2024-10-09 18:12:31 +08:00
hutool.sh update copyright 2025-01-01 23:44:09 +08:00
LICENSE change license 2024-08-13 07:33:39 +08:00
pom.xml prepare M21 2025-02-18 09:18:07 +08:00
README-EN.md fix confilict 2025-02-21 09:12:25 +08:00
README.md fix confilict 2025-02-21 09:12:25 +08:00
SECURITY.md fix code 2023-03-13 11:41:20 +08:00

🍬Make Java Sweet Again.

👉 https://hutool.cn/ 👈

star github star gitcode star



🌎English Documentation


📚简介

Hutool是一个功能丰富且易用的Java工具库,通过诸多实用工具类的使用,旨在帮助开发者快速、便捷地完成各类开发任务。 这些封装的工具涵盖了字符串、数字、集合、编码、日期、文件、IO、加密、数据库JDBC、JSON、HTTP客户端等一系列操作 可以满足各种不同的开发需求。

🎁Hutool往事

  • 2012年一个刚刚步入职场的少年剥离了业务系统中的公共部分取名叫做Common-Tools
  • 2014年他离开热爱的互联网和IT行业将这份热爱倾注于开源并将项目更名为Hutool Hu是怀念曾经公司中一起并肩作战的小伙伴们和那段美好回忆人生难得糊涂我们都在成长但不变的是对Coding的热爱。
  • 现在“他”变成“他们”——一群热心的Committer。而Hutool,数十年如一日已成为众多Java开发者互助的桥梁。
  • 将来Make Java Sweet Again!

🍺Hutool理念

Hutool既是一个工具集,也是一个知识库,我们从不自诩代码原创,大多数工具类都是搬运而来,因此:

  • 你可以引入使用,也可以拷贝和修改使用,而不必标注任何信息只是希望能把bug及时反馈回来。
  • 我们努力健全中文注释,为源码学习者提供良好地学习环境,争取做到人人都能看得懂。

版本选择

Hutool目前主要版本4.x、5.x、6.x选择如下

版本 jdk Maven仓库 主要特点
4.x jdk1.7 cn.hutool/hutool-all/4.x jdk1.7编译
5.x jdk1.8 cn.hutool/hutool-all/5.x jdk1.8编译,使用JavaEE,适配JDK11、17、21
6.x jdk1.8 org.dromara.hutool/hutool-all/6.x jdk1.8编译,使用Jakarta EE,适配JDK11、17、21

🛠️包含组件

模块 介绍
hutool-core 核心包括Bean操作、日期、各种Util等
hutool-cron 定时任务模块提供类Crontab表达式的定时任务
hutool-crypto 加密解密模块,提供对称、非对称和摘要算法封装
hutool-db JDBC封装后的数据操作基于ActiveRecord思想
hutool-extra 扩展模块对第三方封装模板引擎、邮件、Servlet、二维码、Emoji、FTP、分词等
hutool-http 基于HttpUrlConnection、HttpClient、OkHttp的Http客户端封装
hutool-log 功能强大的日志门面
hutool-setting 功能更强大的配置文件封装和工具
hutool-json JSON实现
hutool-poi POI中Excel和Word的封装以及OFD封装
hutool-socket 基于Java的NIO和AIO的Socket封装
hutool-swing Swing和JWT相关封装

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


📝文档

📘中文文档

📘中文备用文档

📙参考API


=======

📦安装

🍊Maven

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


<dependency>
    <groupId>org.dromara.hutool</groupId>
    <artifactId>hutool-all</artifactId>
    <version>6.0.0-M21</version>
</dependency>

🍐Gradle

implementation 'org.dromara.hutool:hutool-all:6.0.0-M21'

📥下载jar

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

🔔️注意 Hutool 6.x支持JDK8+对Android平台没有测试不能保证所有工具类或工具方法可用。

🚽编译安装

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

./hutool.sh install   。/ hutool.sh安装

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


🏗️添砖加瓦

🎋分支说明

Hutool的源码分为两个分支功能如下

分支 作用
v6-master 主分支release版本使用的分支与中央库提交的jar一致不接收任何pr或修改
v6-dev 开发分支默认为下个版本的SNAPSHOT版本接受修改或pr

🐞提供bug反馈或建议

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

🧬贡献代码的步骤

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

📐PR遵照的原则

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

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

💞沟通说明

  1. 提交地issue或PR未回复并开启状态表示还未处理请耐心等待。
  2. 为了保证新issue及时被发现和处理我们会关闭一些描述不足的issue此时你补充说明重新打开即可。
  3. PR被关闭表示被拒绝或需要修改地地方较多重新提交即可。

Star Hutool

Stargazers over time[随时间变化的观星者]https://starchart.cc/dromara/hutool

GitHub Contributor Over Time

Contributor Over Time