2023-04-28 00:43:27 +08:00
< p align = "center" >
2023-04-28 00:37:50 +08:00
< a href = "https://hutool.cn/" > < img alt = "" src = "https://plus.hutool.cn/images/hutool.svg" width = "45%" > < / a >
2021-01-20 17:10:45 +08:00
< / p >
2023-04-28 00:43:27 +08:00
< p align = "center" >
2023-04-16 00:54:24 +08:00
< strong > 🍬Make Java Sweet Again.< / strong >
2021-01-20 17:10:45 +08:00
< / p >
2023-04-28 00:43:27 +08:00
< p align = "center" >
2021-04-22 03:46:58 +08:00
👉 < a href = "https://hutool.cn" > https://hutool.cn/< / a > 👈
2021-01-20 17:10:45 +08:00
< / p >
2023-04-28 00:43:27 +08:00
< p align = "center" >
2023-04-03 19:26:12 +08:00
< a target = "_blank" href = "https://search.maven.org/artifact/org.dromara.hutool/hutool-all" >
2023-04-28 00:37:50 +08:00
< img alt = "" src = "https://img.shields.io/maven-central/v/org.dromara.hutool/hutool-all.svg?label=Maven%20Central" / >
2021-01-20 17:10:45 +08:00
< / a >
2022-01-20 12:30:53 +08:00
< a target = "_blank" href = "http://license.coscl.org.cn/MulanPSL2/index.html" >
2023-04-28 00:37:50 +08:00
< img alt = "" src = "https://img.shields.io/:license-MulanPSL2-blue.svg" / >
2021-01-20 17:10:45 +08:00
< / a >
2021-03-15 11:25:29 +08:00
< a target = "_blank" href = "https://www.oracle.com/java/technologies/javase/javase-jdk8-downloads.html" >
2023-04-28 00:37:50 +08:00
< img alt = "" src = "https://img.shields.io/badge/JDK-8+-green.svg" / >
2021-01-20 17:10:45 +08:00
< / a >
2021-03-21 15:19:13 +08:00
< a target = "_blank" href = "https://travis-ci.com/dromara/hutool" >
2023-04-28 00:37:50 +08:00
< img alt = "" src = "https://travis-ci.com/dromara/hutool.svg?branch=v5-master" / >
2021-01-20 17:10:45 +08:00
< / a >
2021-03-20 18:09:21 +08:00
< a href = "https://www.codacy.com/gh/dromara/hutool/dashboard?utm_source=github.com&utm_medium=referral&utm_content=dromara/hutool&utm_campaign=Badge_Grade" >
2023-04-28 00:37:50 +08:00
< img alt = "" src = "https://app.codacy.com/project/badge/Grade/8a6897d9de7440dd9de8804c28d2871d" / >
2021-01-20 17:10:45 +08:00
< / a >
2021-03-15 11:25:29 +08:00
< a href = "https://codecov.io/gh/dromara/hutool" >
2023-04-28 00:37:50 +08:00
< img alt = "" src = "https://codecov.io/gh/dromara/hutool/branch/v6-master/graph/badge.svg" / >
2021-01-20 17:10:45 +08:00
< / a >
< a target = "_blank" href = "https://gitter.im/hutool/Lobby?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge" >
2023-04-28 00:37:50 +08:00
< img alt = "" src = "https://badges.gitter.im/hutool/Lobby.svg" / >
2021-01-20 17:10:45 +08:00
< / a >
2021-03-12 20:58:14 +08:00
< a target = "_blank" href = 'https://gitee.com/dromara/hutool/stargazers' >
2023-04-28 00:37:50 +08:00
< img alt = "star" src = 'https://gitee.com/dromara/hutool/badge/star.svg?theme=gvp' / >
2021-01-20 17:10:45 +08:00
< / a >
2021-03-15 11:25:29 +08:00
< a target = "_blank" href = 'https://github.com/dromara/hutool' >
2023-04-28 00:37:50 +08:00
< img alt = "github star" src = "https://img.shields.io/github/stars/dromara/hutool.svg?style=social" / >
2021-01-20 17:10:45 +08:00
< / a >
< / p >
< br / >
2023-04-28 00:43:27 +08:00
< p align = "center" >
2022-12-14 17:09:26 +08:00
< a href = "https://qm.qq.com/cgi-bin/qm/qr?k=QtsqXLkHpLjE99tkre19j6pjPMhSay1a&jump_from=webapi" >
2023-04-28 00:37:50 +08:00
< img alt = "" src = "https://img.shields.io/badge/QQ%E7%BE%A4%E2%91%A6-715292493-orange" / > < / a >
2021-01-20 17:10:45 +08:00
< / p >
-------------------------------------------------------------------------------
2021-04-20 11:51:29 +08:00
[**🌎English Documentation** ](README-EN.md )
2021-01-20 17:10:45 +08:00
-------------------------------------------------------------------------------
2021-04-20 11:51:29 +08:00
## 📚简介
2022-04-28 01:59:51 +08:00
2023-04-28 00:37:50 +08:00
`Hutool` 是一个功能丰富且易用的**Java工具库**,通过诸多实用工具类的使用,旨在帮助开发者快速、便捷地完成各类开发任务。
这些封装的工具涵盖了字符串、数字、集合、编码、日期、文件、IO、加密、数据库JDBC、JSON、HTTP客户端等一系列操作,
可以满足各种不同的开发需求。
2021-01-20 17:10:45 +08:00
2023-04-28 00:37:50 +08:00
### 🎁Hutool往事
2021-01-20 17:10:45 +08:00
2023-04-28 00:37:50 +08:00
- 2012年, 一个刚刚步入职场的少年剥离了业务系统中的公共部分, 取名叫做`Common-Tools` 。
- 2014年, 他离开热爱的互联网和IT行业, 将这份热爱倾注于开源, 并将项目更名为`Hutool` ,
`Hu` 是怀念曾经公司中一起并肩作战的小伙伴们和那段美好回忆, 人生难得糊涂, 我们都在成长, 但不变的是对Coding的热爱。
- 现在, “他”变成“他们”——一群热心的Committer。而`Hutool` ,数十年如一日, 已成为众多Java开发者互助的桥梁。
- 将来, Make Java Sweet Again!
2021-01-20 17:10:45 +08:00
2023-04-28 00:37:50 +08:00
### 🍺Hutool理念
2021-01-20 17:10:45 +08:00
2023-04-28 00:37:50 +08:00
`Hutool` 既是一个工具集,也是一个知识库,我们从不自诩代码原创,大多数工具类都是**搬运**而来,因此:
2021-01-20 17:10:45 +08:00
2023-04-28 00:37:50 +08:00
- 你可以引入使用,也可以**拷贝**和修改使用,而**不必标注任何信息**, 只是希望能把bug及时反馈回来。
- 我们努力健全**中文**注释,为源码学习者提供良好地学习环境,争取做到人人都能看得懂。
2021-01-20 17:10:45 +08:00
-------------------------------------------------------------------------------
2021-04-20 11:51:29 +08:00
## 🛠️包含组件
2022-04-28 01:59:51 +08:00
2023-04-28 00:37:50 +08:00
| 模块 | 介绍 |
|----------------|-------------------------------------------------|
| 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相关封装 |
2021-01-20 17:10:45 +08:00
可以根据需求对每个模块单独引入,也可以通过引入`hutool-all` 方式引入所有模块。
-------------------------------------------------------------------------------
2022-04-28 01:59:51 +08:00
## 📝文档
2021-01-20 17:10:45 +08:00
2021-04-20 11:51:29 +08:00
[📘中文文档 ](https://www.hutool.cn/docs/ )
2021-01-20 17:10:45 +08:00
2022-03-09 15:48:31 +08:00
[📘中文备用文档 ](https://plus.hutool.cn/docs/#/ )
2021-04-20 11:51:29 +08:00
[📙参考API ](https://apidoc.gitee.com/dromara/hutool/ )
2021-01-20 17:10:45 +08:00
-------------------------------------------------------------------------------
2021-10-21 22:42:42 +08:00
## 🪙支持Hutool
### 💳捐赠
如果你觉得Hutool不错, 可以捐赠请维护者吃包辣条~,在此表示感谢^_^。
[Gitee上捐赠 ](https://gitee.com/dromara/hutool )
### 👕周边商店
你也可以通过购买Hutool的周边商品来支持Hutool维护哦!
我们提供了印有Hutool Logo的周边商品, 欢迎点击购买支持:
2021-12-12 18:41:43 +08:00
👉 [Hutool 周边商店 ](https://market.m.taobao.com/apps/market/content/index.html?wh_weex=true&contentId=331724720170 ) 👈
2021-10-21 22:42:42 +08:00
-------------------------------------------------------------------------------
2021-04-20 11:51:29 +08:00
## 📦安装
2021-01-20 17:10:45 +08:00
2021-04-22 03:30:56 +08:00
### 🍊Maven
2022-04-28 01:59:51 +08:00
2021-01-20 17:10:45 +08:00
在项目的pom.xml的dependencies中加入以下内容:
```xml
2022-04-28 01:59:51 +08:00
2021-01-20 17:10:45 +08:00
< dependency >
2023-04-03 19:26:12 +08:00
< groupId > org.dromara.hutool< / groupId >
2022-04-28 01:59:51 +08:00
< artifactId > hutool-all< / artifactId >
2023-05-05 23:08:04 +08:00
< version > 6.0.0.M4< / version >
2021-01-20 17:10:45 +08:00
< / dependency >
```
2021-04-22 03:30:56 +08:00
### 🍐Gradle
2022-04-28 01:59:51 +08:00
2021-01-20 17:10:45 +08:00
```
2023-05-05 23:08:04 +08:00
implementation 'org.dromara.hutool:hutool-all:6.0.0.M4'
2021-01-20 17:10:45 +08:00
```
2021-04-22 03:30:56 +08:00
### 📥下载jar
2021-01-20 17:10:45 +08:00
2021-04-22 03:30:56 +08:00
点击以下链接,下载`hutool-all-X.X.X.jar` 即可:
2021-01-20 17:10:45 +08:00
2023-05-05 23:08:04 +08:00
- [Maven中央库 ](https://repo1.maven.org/maven2/org/dromara/hutool/hutool-all/6.0.0.M4/ )
2021-01-20 17:10:45 +08:00
2021-04-20 11:51:29 +08:00
> 🔔️注意
2023-04-28 00:37:50 +08:00
> Hutool 6.x支持JDK8+, 对Android平台没有测试, 不能保证所有工具类或工具方法可用。
2021-01-20 17:10:45 +08:00
2021-04-22 03:30:56 +08:00
### 🚽编译安装
2021-01-20 17:10:45 +08:00
2022-04-28 01:59:51 +08:00
访问Hutool的Gitee主页: [https://gitee.com/dromara/hutool ](https://gitee.com/dromara/hutool )
2022-04-29 00:32:45 +08:00
下载整个项目源码( v6-master或v6-dev分支都可) 然后进入Hutool项目目录执行:
2021-01-20 17:10:45 +08:00
```sh
./hutool.sh install
```
然后就可以使用Maven引入了。
-------------------------------------------------------------------------------
2021-04-20 11:51:29 +08:00
## 🏗️添砖加瓦
2021-01-20 17:10:45 +08:00
2021-04-20 11:51:29 +08:00
### 🎋分支说明
2021-01-20 17:10:45 +08:00
Hutool的源码分为两个分支, 功能如下:
2023-03-13 11:41:20 +08:00
| 分支 | 作用 |
|-----------|--------------------------------------------|
2022-04-29 00:32:45 +08:00
| v6-master | 主分支, release版本使用的分支, 与中央库提交的jar一致, 不接收任何pr或修改 |
2023-03-13 11:41:20 +08:00
| v6-dev | 开发分支, 默认为下个版本的SNAPSHOT版本, 接受修改或pr |
2021-01-20 17:10:45 +08:00
2021-04-20 11:51:29 +08:00
### 🐞提供bug反馈或建议
2021-01-20 17:10:45 +08:00
提交问题反馈请说明正在使用的JDK版本呢、Hutool版本和相关依赖库版本。
2021-03-12 20:58:14 +08:00
- [Gitee issue ](https://gitee.com/dromara/hutool/issues )
2021-03-15 11:25:29 +08:00
- [Github issue ](https://github.com/dromara/hutool/issues )
2021-01-20 17:10:45 +08:00
2021-04-20 11:51:29 +08:00
### 🧬贡献代码的步骤
2021-01-20 17:10:45 +08:00
1. 在Gitee或者Github上fork项目到自己的repo
2. 把fork过去的项目也就是你的项目clone到你的本地
2022-04-29 00:32:45 +08:00
3. 修改代码( 记得一定要修改v6-dev分支)
4. commit后push到自己的库( v6-dev分支)
2021-01-20 17:10:45 +08:00
5. 登录Gitee或Github在你首页可以看到一个 pull request 按钮,点击它,填写一些说明信息,然后提交即可。
6. 等待维护者合并
2021-04-20 11:51:29 +08:00
### 📐PR遵照的原则
2021-01-20 17:10:45 +08:00
Hutool欢迎任何人为Hutool添砖加瓦, 贡献代码, 不过维护者是一个强迫症患者, 为了照顾病人, 需要提交的pr( pull request) 符合一些规范, 规范如下:
1. 注释完备, 尤其每个新增的方法应按照Java文档规范标明方法说明、参数说明、返回值说明等信息, 必要时请添加单元测试, 如果愿意, 也可以加上你的大名。
2. Hutool的缩进按照Eclipse( ~~不要跟我说IDEA多好用, 维护者非常懒, 学不会~~, IDEA真香, 改了Eclipse快捷键后舒服多了) 默认( tab) 缩进, 所以请遵守( 不要和我争执空格与tab的问题, 这是一个病人的习惯) 。
3. 新加的方法不要使用第三方库的方法, Hutool遵循无依赖原则( 除非在extra模块中加方法工具) 。
2023-04-28 00:37:50 +08:00
4. 请pull request到`v6-dev` 分支。Hutool在6.x版本后使用了新的分支: `v6-master` 是主分支, 表示已经发布中央库的版本, 这个分支不允许pr, 也不允许修改。
### 💞沟通说明
1. 提交地issue或PR未回复并开启状态表示还未处理, 请耐心等待。
2. 为了保证新issue及时被发现和处理, 我们会关闭一些描述不足的issue, 此时你补充说明重新打开即可。
3. PR被关闭, 表示被拒绝或需要修改地地方较多, 重新提交即可。
2021-01-20 17:10:45 +08:00
-------------------------------------------------------------------------------
2021-04-20 11:51:29 +08:00
## ⭐Star Hutool
2021-03-12 09:28:37 +08:00
2021-04-13 08:59:25 +08:00
[](https://starchart.cc/dromara/hutool)
2023-04-28 00:37:50 +08:00
### GitHub Contributor Over Time
[](https://git-contributor.com?chart=contributorOverTime& repo=dromara/hutool)