❓背景
灵魂拷问1:还在为新项目工具类搬迁而烦恼?
灵魂拷问2:还在为项目中工具类维护而烦恼?

简述
Hutool它是一个Java工具集类库,包含了许多静态方法的封装:流处理、时间日期处理、正则处理、加解密处理、文件处理、集合处理等,可以说是项目中几乎所有XxxxUtil的替代品,它可以使你更多的关注代码逻辑,优雅的写出高效代码,避免“复制粘贴,改改再战”。
”️组件
模块划分预览,可以根据需求对每个模块单独引入,也可以通过引入hutool-all方式引入所有模块。

☀️常用
⚠️只列举部门方法,具体可查看源码学习!!!
1、核心工具集
1.1、日期时间工具-DateUtil
日期转换再常用不外了,字符串转日期格局、日期格局转指定字符串格局、获取当前系统日期、时间差
// 自定义日期格局转化String dateStr = "2017-03-01";Date date = DateUtil.parse(dateStr, "yyyy-MM-dd");
1.2、农历日期-ChineseDate
提供了生肖、天干地支、传统节日等方法。
//通过公历构建ChineseDate date = new ChineseDate(DateUtil.parseDate("2020-01-25"));// 一月date.getChineseMonth();// 正月date.getChineseMonthName();// 初一date.getChineseDay();// 庚子date.getCyclical();// 生肖:鼠date.getChineseZodiac();// 传统节日(部门支持,逗号分隔):春节date.getFestivals();// 庚子鼠年 正月初一date.toString();
1.3、计时器工具-TimeInterval
计算方法或过程执行的时间,支持分组计时,利便对比时间
TimeInterval timer = DateUtil.timer();//---------------------------------//-------这是执行过程//---------------------------------timer.interval();//花费毫秒数timer.intervalRestart();//返回花费时间,并重置开始时间timer.intervalMinute();//花费分钟数
1.4、文件类型判定-FileTypeUtil
在文件上传时,有时候我们需要判定文件类型。但是又不能简朴的通过扩展名来判定(防止恶意脚本等通过上传到服务器上),于是我们需要在服务端通过读取文件的首部几个二进制位来判定常用的文件类型。
File file = FileUtil.file("d:/test.jpg");String type = FileTypeUtil.getType(file);//输出 jpg则说明确实为jpg文件Console.log(type);
1.5、符串工具-StrUtil
这个工具的用处类似于Apache Commons Lang中的StringUtil,字符串判空操纵就不再累述,StrUtil只做增强:sub、removePrefix、removeSuffix
// 去掉字符串的后缀,例如去个文件名的扩展名。String fileName = StrUtil.removeSuffix("pretty_girl.jpg", ".jpg") //fileName -> pretty_girl
1.6、16进制工具-HexUtil
16进制一般针对无法显示的一些二进制进行显示,常用于: 1、图片的字符串表现形式 2、加密解密 3、编码转换
String str = "我是一个字符串";String hex = HexUtil.encodeHexStr(str, CharsetUtil.CHARSET_UTF_8);//hex是://e68891e698afe4b880e4b8aae5ad97e7aca6e4b8b2String decodedStr = HexUtil.decodeHexStr(hex);//解码后与str相同
1.7、Escape工具-EscapeUtil
转义和反转义工具类Escape / Unescape。escape采用ISO Latin字符集对指定的字符串进行编码。所有的空格符、标点符号、特殊字符以及其他非ASCII字符都将被转化成%xx格局的字符编码(xx即是该字符在字符集表里面的编码的16进制数字)。此类中的方法对应Javascript中的escape()函数和unescape()函数。

1.8、URL工具-URLUtil
URL(Uniform Resource Locator)中文名为同一资源定位符,有时也被俗称为网页地址。表示为互联网上的资源,如网页或者FTP地址。在Java中,也可以使用URL表示Classpath中的资源(Resource)地址。
•URLUtil.normalize 标准化化URL链接。对于不带http://头的地址做简朴补全。
String url = "http://www.hutool.cn//aaa/bbb";// 结果为:http://www.hutool.cn/aaa/bbbString normalize = URLUtil.normalize(url);url = "http://www.hutool.cn//aaa/bbb?a=1&b=2";// 结果为:http://www.hutool.cn/aaa/bbb?a=1&b=2normalize = URLUtil.normalize(url);
•URLUtil.encode 封装URLEncoder.encode,将需要转换的内容(ASCII码形式之外的内容),用十六进制表示法转换出来,并在之前加上%开头。
String body = "366466 - 副本.jpg";// 结果为:366466%20-%20%E5%89%AF%E6%9C%AC.jpgString encode = URLUtil.encode(body);
1.9、枚举工具-EnumUtil
枚举(enum)算一种“语法糖”,是指一个经由排序的、被打包成一个单一实体的项列表。一个枚举的实例可以使用枚举项列表中任意单一项的值。枚举在各个语言当中都有着广泛的应用,通常用来表示诸如颜色、方式、种别、状态等等数量有限、形式离散、表达又极为明确的量。Java从JDK5开始,引入了对枚举的支持。
//定义枚举 public enum TestEnum{ TEST1("type1"), TEST2("type2"), TEST3("type3"); private TestEnum(String type) { this.type = type; } private String type; public String getType() { return this.type; } }// 获取枚举类中所有枚举对象的name列表List<String> names = EnumUtil.getNames(TestEnum.class); //结果:[TEST1, TEST2, TEST3]// 获得枚举类中各枚举对象下指定字段的值List<Object> types = EnumUtil.getFieldValues(TestEnum.class, "type"); //结果:[type1, type2, type3]
1.10、数字工具-NumberUtil
数字工具针对数学运算做工具性封装
// 格式化为指定字符串long c = 299792458;//光速String format = NumberUtil.decimalFormat(",###", c);//299,792,458
1.11、数组工具-ArrayUtil
数组工具类主要针对原始类型数组和泛型数组相关方案进行封装
// 数组判空int[] a = {}; int[] b = null; ArrayUtil.isEmpty(a); ArrayUtil.isEmpty(b);
1.12、随机工具-RandomUtil
RandomUtil主要针对JDK中Random对象做封装,严格来说,Java产生的随机数都是伪随机数,因此Hutool封装后产生的随机结果也是伪随机结果。不外这种随机结果对于大多数情况已经够用。
// 例如我们想产生一个[10, 100)的随机数,则:int c = RandomUtil.randomInt(10, 100);
1.13、独一ID工具-IdUtil
在分布式环境中,独一ID天生应用十分广泛,天生方法也多种多样,Hutool针对一些常用天生策略做了简朴封装。包括UUID、ObjectId(MongoDB)、Snowflake(Twitter)
// 天生的UUID是带-的字符串,类似于:a5c8a5e8-df2b-4706-bea4-08d0939410e3String uuid = IdUtil.randomUUID();// 天生的是不带-的字符串,类似于:b17f24ff026d40949c85a24f4f375d42String simpleUUID = IdUtil.simpleUUID();
1.14、正则工具-ReUtil
在文本处理中,正则表达式几乎是全能的,但是Java的正则表达式有时候处理一些事情仍是有些繁琐
// 给定字符串是否匹配给定正则String content = "ZZZaaabbbccc中文1234";boolean isMatch = ReUtil.isMatch("w+[u4E00-u9FFF]+d+", content);Assert.assertTrue(isMatch);
1.15、身份证工具-IdcardUtil
支持大陆15位、18位身份证,港澳台10位身份证
String ID_18 = "321083197812162119";String ID_15 = "150102880730303";//是否有效boolean valid = IdcardUtil.isValidCard(ID_18);boolean valid15 = IdcardUtil.isValidCard(ID_15);//转换String convert15To18 = IdcardUtil.convert15To18(ID_15);//春秋DateTime date = DateUtil.parse("2017-04-10"); int age = IdcardUtil.getAgeByIdCard(ID_18, date);int age2 = IdcardUtil.getAgeByIdCard(ID_15, date);//生日String birth = IdcardUtil.getBirthByIdCard(ID_18);String birth2 = IdcardUtil.getBirthByIdCard(ID_15);//省份String province = IdcardUtil.getProvinceByIdCard(ID_18);String province2 = IdcardUtil.getProvinceByIdCard(ID_15);
1.16、信息脱敏工具-DesensitizedUtil
在数据处理或清洗中,可能涉及到许多隐私信息的脱敏工作,因此Hutool针对常用的信息封装了一些脱敏方法。
// 以身份证号码为例:5***************1XDesensitizedUtil.idCardNum("51343620000320711X", 1, 2);
1.17、社会信用代码工具-CreditCodeUtil
法人和其他组织同一社会信用代码轨制,相当于让法人和其他组织拥有了一个全国同一的“身份证号”,由一下五部门组成: 第一部门:登记治理部分代码1位 (数字或大写英文字母) 第二部门:机构种别代码1位 (数字或大写英文字母) 第三部门:登记治理机关行政区划码6位 (数字) 第四部门:主体标识码(组织机构代码)9位 (数字或大写英文字母) 第五部门:校验码1位 (数字或大写英文字母)
// 校验是否为社会信用代码String testCreditCode = "91310110666007217T";// trueCreditCodeUtil.isCreditCode(testCreditCode);
1.18、字段验证器-Validator
验证给定字符串是否满意指定前提,一般用在表单字段验证里。
// 验证是否为邮箱boolean isEmail = Validator.isEmail("loolly@gmail.com")// 如无法满意需求,可通过该正则验证Validator.isMactchRegex("需要验证字段的正则表达式", "被验证内容")
1.19、Bean工具-BeanUtil
Bean工具类主要是针对这些setXXX和getXXX方法进行操纵,好比将Bean对象转为Map等等
// 使用Map填充beanHashMap<String, Object> map = CollUtil.newHashMap();map.put("name", "Joe");map.put("age", 12);map.put("openId", "DFDFSDFWERWER");SubPerson person = BeanUtil.fillBeanWithMap(map, new SubPerson(), false);
1.20、集合工具-CollUtil
这个工具主要增加了对数组、集合类的操纵。
// 将集合转换为字符串String[] col= new String[]{"a","b","c","d","e"};List<String> colList = CollUtil.newArrayList(col);String str = CollUtil.join(colList, "#"); //str -> a#b#c#d#e
1.21、列表工具-ListUtil
List在集合中中使用最为频繁,因此新版本的Hutool中针对List单独封装了工具方法。
// 列表截取final List<Integer> of = ListUtil.of(1, 2, 3, 4);// [3, 4]final List<Integer> sub = ListUtil.sub(of, 2, 4);// 对子列表操纵不影响原列表sub.remove(0);
1.22、Unicode编码转换工具-UnicodeUtil
此工具主要针对类似于u4e2du6587这类Unicode字符做一些特殊转换。
// 字符串转Unicode 第二个参数true表示跳过ASCII字符(只跳过可见字符)String s = UnicodeUtil.toUnicode("aaa123中文", true); //结果aaa123u4e2du6587// Unicode转字符串String res = UnicodeUtil.toString("aaaU4e2du6587u111urtyuu0026"); //结果aaa中文u111urtyu&
1.23、Map工具-MapUtil
MapUtil是针对Map的一一列工具方法的封装,包括getXXX的快捷值转换方法。
// reverse Map的键和值互换Map<String, String> map = MapUtil.newHashMap(); map.put("a", "1"); map.put("b", "2"); map.put("c", "3"); map.put("d", "4");Map<String, String> map2 = MapUtil.reverse(map);
结果为:
{ "1": "a", "2": "b", "3": "c", "4": "d",}
1.24、Base64编码解码
Base64编码是用64(2的6次方)个ASCII字符来表示256(2的8次方)个ASCII字符,也就是三位二进制数组经由编码后变为四位的ASCII字符显示,长度比原来增加1/3。
String a = "伦家是一个非常长的字符串";// 5Lym5a625piv5LiA5Liq6Z2e5bi46ZW/55qE5a2X56ym5LiyString encode = Base64.encode(a);// 还原为aString decodeStr = Base64.decodeStr(encode);
1.25、数学相关-MathUtil
此工具是NumberUtil的一个增补,NumberUtil偏向于简朴数学计算的封装,MathUtil偏向复杂数学计算。

1.26、图片工具-ImgUtil
针对awt中图片处理进行封装,这些封装包括:缩放、裁剪、转为黑白、加水印等操纵。
// 图片类型转换png->jpgImgUtil.convert(FileUtil.file("e:/test2.png"), FileUtil.file("e:/test2Convert.jpg"));// 彩色转黑白ImgUtil.gray(FileUtil.file("d:/logo.png"), FileUtil.file("d:/result.png"));// 添加文字水印ImgUtil.pressText( FileUtil.file("e:/pic/face.jpg"), FileUtil.file("e:/pic/test2_result.png"), "版权所有", Color.WHITE, //文字 new Font("黑体", Font.BOLD, 100), //字体 0, //x坐标修正值。 默认在中间,偏移量相对于中间偏移 0, //y坐标修正值。 默认在中间,偏移量相对于中间偏移 0.8f//透明度:alpha 必需是范围 [0.0, 1.0] 之内(包含边界值)的一个浮点数字 );
1.27、网络工具-NetUtil
在日常开发中,网络连接这块儿必不可少。日常用到的一些功能,隐藏掉部门IP地址、绝对相对路径的转换等等。
String ip= "127.0.0.1";long iplong = 2130706433L;// 根据long值获取ip v4地址String ip= NetUtil.longToIpv4(iplong);// 根据ip地址计算出long型的数据long ip= NetUtil.ipv4ToLong(ip);// 检测本地端口可用性boolean result= NetUtil.isUsableLocalPort(6379);// 是否为有效的端口boolean result= NetUtil.isValidPort(6379);// 隐藏掉IP地址String result =NetUtil.hideIpPart(ip);
2、JSON
2.1、JSON工具-JSONUtil
针对JSONObject和JSONArray的静态快捷方法集合
// JSON字符串解析String html = "{"name":"Something must have been changed since you leave"}";JSONObject jsonObject = JSONUtil.parseObj(html);jsonObject.getStr("name");// XML字符串转JSONString s = "<sfzh>123</sfzh><sfz>456</sfz><name>aa</name><gender>1</gender>"; JSONObject json = JSONUtil.parseFromXml(s); json.get("sfzh"); json.get("name");// JSON转XMLfinal JSONObject put = JSONUtil.createObj().set("aaa", "你好").set("键2", "test"); // <aaa>你好</aaa><键2>test</键2> final String s = JSONUtil.toXmlStr(put);// JSON转BeanString json = "{"ADT":[[{"BookingCode":["N","N"]}]]}"; Price price = JSONUtil.toBean(json, Price.class); price.getADT().get(0).get(0).getBookingCode().get(0);
3、加密解密
3.1、加密解密工具-SecureUtil
SecureUtil主要针对常用加密算法构建快捷方式,还有提供一些密钥天生的快捷工具方法。
// AES对称加解密String content = "test中文";// 随机天生密钥byte[] key = SecureUtil.generateKey(SymmetricAlgorithm.AES.getValue()).getEncoded();// 构建AES aes = SecureUtil.aes(key);// 加密byte[] encrypt = aes.encrypt(content);// 解密byte[] decrypt = aes.decrypt(encrypt);// 加密为16进制表示String encryptHex = aes.encryptHex(content);// 解密为字符串String decryptStr = aes.decryptStr(encryptHex, CharsetUtil.CHARSET_UTF_8);
4、HTTP客户端
4.1、Http客户端工具类-HttpUtil
基于JDK的HttpUrlConnection封装完成,完整支持https、署理和文件上传、以及URL参数编解码等。
GET哀求栗子:
// 最简朴的HTTP哀求,可以自动通过header等信息判定编码,不区分HTTP和HTTPSString result1= HttpUtil.get("https://www.baidu.com");// 当无法识别页面编码的时候,可以自定义哀求页面的编码String result2= HttpUtil.get("https://www.baidu.com", CharsetUtil.CHARSET_UTF_8);//可以单独传入http参数,这样参数会自动做URL编码,拼接在URL中HashMap<String, Object> paramMap = new HashMap<>();paramMap.put("city", "北京");String result3= HttpUtil.get("https://www.baidu.com", paramMap);
POST哀求栗子:
HashMap<String, Object> paramMap = new HashMap<>();paramMap.put("city", "北京");String result= HttpUtil.post("https://www.baidu.com", paramMap);
文件上传栗子:
HashMap<String, Object> paramMap = new HashMap<>();//文件上传只需将参数中的键指定(默认file),值设为文件对象即可,对于使用者来说,文件上传与普通表单提交并无区别paramMap.put("file", FileUtil.file("D:face.jpg"));String result= HttpUtil.post("https://www.baidu.com", paramMap);
4.2、HTML工具类-HtmlUtil
如我们在使用爬虫爬取HTML页面后,需要对返回页面的HTML内容做一定处理,好比去掉指定标签(例如广告栏等)、去除JS、去掉样式等等,这些操纵都可以使用HtmlUtil完成。
// 转义HTML特殊字符String html = "<html><body>123"123"</body></html>";// 结果为:<html><body>123"123"</body></html>String escape = HtmlUtil.escape(html);// 还原被转义的HTML特殊字符String escape = "<html><body>123"123"</body></html>"; // 结果为:<html><body>123"123"</body></html> String unescape = HtmlUtil.unescape(escape);// 清除指定HTML标签和被标签包抄的内容String str = "pre<img src="xxx/dfdsfds/test.jpg">";// 结果为:pre String result = HtmlUtil.removeHtmlTag(str, "img");// 清除所有HTML标签,但是保存标签内的内容 String str = "pre<div class="test_div">
dfdsfdsfdsf
</div><div class="test_div">BBBB</div>"; // 结果为:pre
dfdsfdsfdsf
BBBB String result = HtmlUtil.cleanHtmlTag(str);// 清除指定HTML标签,不包括内容String str = "pre<div class="test_div">abc</div>"; // 结果为:preabc String result = HtmlUtil.unwrapHtmlTag(str, "div");// 过滤HTML文本,防止XSS攻击String html = "<alert></alert>"; // 结果为:"" String filter = HtmlUtil.filter(html);
5、扩展工具集
5.1、拼音工具-PinyinUtil
引入拼音库(TinyPinyin、JPinyin、Pinyin4j)其中任意一个引擎,从而实现获取汉语拼音、拼音首字母
// 获取拼音:"ni hao" String pinyin = PinyinUtil.getPinyin("你好", " "); // 获取拼音首字母:"h, s, d, y, g"String result = PinyinUtil.getFirstLetter("H是第一个", ", ");
5.2、Emoji工具-EmojiUtil
引入表情依靠,实现表情转义、表情转html、转义的别号转表情
<!-- 表情依靠 --><dependency> <groupId>com.vdurmont</groupId> <artifactId>emoji-java</artifactId> <version>4.0.0</version></dependency>
// 转义Emoji字符String alias = EmojiUtil.toAlias("");//:smile:// 将转义的别号转为Emoji字符String emoji = EmojiUtil.toUnicode(":smile:");//// 将字符串中的Unicode Emoji字符转换为HTML表现形式String alias = EmojiUtil.toHtml("");//
5.3、二维码工具-QrCodeUtil
引入zxing库依靠(理论上你引入的版本应与此版本一致或比这个版本新),实现二维码的天生(二维码可附带logo图标)以及识别二维码
<!-- zxing库依靠 --><dependency> <groupId>com.google.zxing</groupId> <artifactId>core</artifactId> <version>3.3.3</version></dependency>
// 自定义参数天生指定url对应的二维码到文件QrConfig config = new QrConfig(300, 300);// 设置边距,既二维码和背景之间的边距config.setMargin(3);// 设置前景色,既二维码颜色(青色)config.setForeColor(Color.CYAN.getRGB());// 设置背景色(灰色)config.setBackColor(Color.GRAY.getRGB());// 天生二维码到文件,也可以到流QrCodeUtil.generate("http://hutool.cn/", config, FileUtil.file("e:/qrcode.jpg"));// 识别二维码(decode -> "http://hutool.cn/" )String decode = QrCodeUtil.decode(FileUtil.file("d:/qrcode.jpg"));
5.4、邮件工具-MailUtil
Hutool对所有第三方都是可选依靠,因此在使用MailUtil时需要自行引入第三方依靠。支持群发、带附件、自定义邮件服务器
<!-- java-mail依靠 --><!-- 说明 com.sun.mail是javax.mail进级后的版本,新版本包名做了变更。 --><dependency> <groupId>com.sun.mail</groupId> <artifactId>javax.mail</artifactId> <version>1.6.2</version></dependency>
// 发送普通文本邮件,最后一个参数可选是否添加多个附件MailUtil.send("hutool@foxmail.com", "测试", "邮件来自Hutool测试", false);// 发送HTML格局的邮件并附带附件,最后一个参数可选是否添加多个附件:MailUtil.send("hutool@foxmail.com", "测试", "<h1>邮件来自Hutool测试</h1>", true, FileUtil.file("d:/aaa.xml"));// 群发邮件,可选HTML或普通文本,可选多个附件:ArrayList<String> tos = CollUtil.newArrayList( "person1@bbb.com", "person2@bbb.com", "person3@bbb.com", "person4@bbb.com"); MailUtil.send(tos, "测试", "邮件来自Hutool群发测试", false);
官方文档: https://www.hutool.cn/docs/#/Github地址: https://github.com/dromara/hutoolGitee地址: https://gitee.com/dromara/hutool
作者:京东零售 马雄伟来源:京东云开发者社区 转载请注明来源
❓背景
灵魂拷问1:还在为新项目工具类搬迁而烦恼?
灵魂拷问2:还在为项目中工具类维护而烦恼?

简述
Hutool它是一个Java工具集类库,包含了许多静态方法的封装:流处理、时间日期处理、正则处理、加解密处理、文件处理、集合处理等,可以说是项目中几乎所有XxxxUtil的替代品,它可以使你更多的关注代码逻辑,优雅的写出高效代码,避免“复制粘贴,改改再战”。
”️组件
模块划分预览,可以根据需求对每个模块单独引入,也可以通过引入hutool-all方式引入所有模块。
