hutool/README.md

216 lines
11 KiB
Markdown
Raw Normal View History

2021-01-20 17:10:45 +08:00
<p align="center">
<a href="https://hutool.cn/"><img src="https://cdn.jsdelivr.net/gh/looly/hutool-site/images/logo.jpg" width="45%"></a>
</p>
<p align="center">
<strong>A set of tools that keep Java sweet.</strong>
</p>
<p align="center">
<a href="https://hutool.cn">https://hutool.cn/</a>
</p>
<p align="center">
<a target="_blank" href="https://search.maven.org/artifact/cn.hutool/hutool-all">
<img src="https://img.shields.io/maven-central/v/cn.hutool/hutool-all.svg?label=Maven%20Central" />
</a>
<a target="_blank" href="https://license.coscl.org.cn/MulanPSL2/">
<img src="https://img.shields.io/:license-MulanPSL2-blue.svg" />
</a>
2021-03-15 11:25:29 +08:00
<a target="_blank" href="https://www.oracle.com/java/technologies/javase/javase-jdk8-downloads.html">
2021-01-20 17:10:45 +08:00
<img src="https://img.shields.io/badge/JDK-8+-green.svg" />
</a>
2021-03-16 13:46:30 +08:00
<a target="_blank" href="https://travis-ci.org/dromara/hutool">
2021-03-15 11:25:29 +08:00
<img src="https://travis-ci.org/dromara/hutool.svg?branch=v4-master" />
2021-01-20 17:10:45 +08:00
</a>
2021-03-15 11:25:29 +08:00
<a href="https://www.codacy.com/app/dromara/hutool">
2021-01-20 17:10:45 +08:00
<img src="https://api.codacy.com/project/badge/Grade/3e1b8a70248c46579b7b0d01d60c6377"/>
</a>
2021-03-15 11:25:29 +08:00
<a href="https://codecov.io/gh/dromara/hutool">
<img src="https://codecov.io/gh/dromara/hutool/branch/v5-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">
<img src="https://badges.gitter.im/hutool/Lobby.svg" />
</a>
2021-03-12 20:58:14 +08:00
<a target="_blank" href='https://gitee.com/dromara/hutool/stargazers'>
<img src='https://gitee.com/dromara/hutool/badge/star.svg?theme=gvp' alt='star'/>
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'>
<img src="https://img.shields.io/github/stars/dromara/hutool.svg?style=social" alt="github star"/>
2021-01-20 17:10:45 +08:00
</a>
<a target="_blank" href='https://app.netlify.com/sites/hutool/deploys'>
<img src="https://api.netlify.com/api/v1/badges/7e0824f9-5f9a-4df0-89dd-b2fccfbeccb1/deploy-status" alt="netlify"/>
</a>
</p>
<br/>
<p align="center">
<a href="https://qm.qq.com/cgi-bin/qm/qr?k=0wwldaU0E8r-ZzHl_wma33W7420zwXYi&jump_from=webapi"><img src="https://img.shields.io/badge/QQ%E7%BE%A4%E2%91%A4-956375658-orange"/></a>
</p>
-------------------------------------------------------------------------------
[**English Documentation**](README-EN.md)
-------------------------------------------------------------------------------
## 简介
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-all`方式引入所有模块。
-------------------------------------------------------------------------------
## 文档
[中文文档](https://www.hutool.cn/docs/)
2021-03-12 21:06:41 +08:00
[参考API](https://apidoc.gitee.com/dromara/hutool/)
2021-01-20 17:10:45 +08:00
[视频介绍](https://www.bilibili.com/video/BV1bQ4y1M7d9?p=2)
-------------------------------------------------------------------------------
## 安装
### Maven
在项目的pom.xml的dependencies中加入以下内容:
```xml
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
2021-03-18 23:07:14 +08:00
<version>5.6.2</version>
2021-01-20 17:10:45 +08:00
</dependency>
```
### Gradle
```
2021-03-18 23:07:14 +08:00
compile 'cn.hutool:hutool-all:5.6.2'
2021-01-20 17:10:45 +08:00
```
### 非Maven项目
点击以下任一链接,下载`hutool-all-X.X.X.jar`即可:
2021-03-18 23:07:14 +08:00
- [Maven中央库](https://repo1.maven.org/maven2/cn/hutool/hutool-all/5.6.2/)
2021-01-20 17:10:45 +08:00
> 注意
> Hutool 5.x支持JDK8+对Android平台没有测试不能保证所有工具类或工具方法可用。
> 如果你的项目使用JDK7请使用Hutool 4.x版本
### 编译安装
2021-03-12 20:58:14 +08:00
访问Hutool的Gitee主页[https://gitee.com/dromara/hutool](https://gitee.com/dromara/hutool) 下载整个项目源码v5-master或v5-dev分支都可然后进入Hutool项目目录执行
2021-01-20 17:10:45 +08:00
```sh
./hutool.sh install
```
然后就可以使用Maven引入了。
-------------------------------------------------------------------------------
## 添砖加瓦
### 分支说明
Hutool的源码分为两个分支功能如下
| 分支 | 作用 |
|-----------|---------------------------------------------------------------|
| v5-master | 主分支release版本使用的分支与中央库提交的jar一致不接收任何pr或修改 |
| v5-dev | 开发分支默认为下个版本的SNAPSHOT版本接受修改或pr |
### 提供bug反馈或建议
提交问题反馈请说明正在使用的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
### 贡献代码的步骤
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也不允许修改。
-------------------------------------------------------------------------------
2021-03-12 09:28:37 +08:00
## Star Hutool
2021-03-12 20:58:14 +08:00
[![Giteye chart](https://chart.giteye.net/gitee/dromara/hutool/GMSL7VDA.png)](https://giteye.net/chart/GMSL7VDA)
2021-03-12 09:28:37 +08:00
2021-01-20 17:10:45 +08:00
## 捐赠
如果你觉得Hutool不错可以捐赠请维护者吃包辣条~,在此表示感谢^_^。
点击以下链接,将页面拉到最下方点击“捐赠”即可。
2021-03-12 20:58:14 +08:00
[前往捐赠](https://gitee.com/dromara/hutool)
2021-01-20 17:10:45 +08:00
## 公众号
2021-03-18 22:27:55 +08:00
#### 欢迎关注Hutool合作的公众号
2021-01-20 17:10:45 +08:00
2021-03-18 22:27:55 +08:00
![Java2B](https://cdn.jsdelivr.net/gh/looly/hutool-site/images/qrcode.jpg)
#### Dromara开源组织公众号
![Dromara](https://dromara.org/img/qrcode/qrcode_1.png)