程序员scholar 程序员scholar
首页
  • Java 基础

    • JavaSE
    • JavaIO
    • JavaAPI速查
  • Java 高级

    • JUC
    • JVM
    • Java新特性
    • 设计模式
  • Web 开发

    • Servlet
    • Java网络编程
  • Web 标准

    • HTML
    • CSS
    • JavaScript
  • 前端框架

    • Vue2
    • Vue3
    • Vue3 + TS
    • 微信小程序
    • uni-app
  • 工具与库

    • jQuery
    • Ajax
    • Axios
    • Webpack
    • Vuex
    • WebSocket
    • 第三方登录
  • 后端与语言扩展

    • ES6
    • Typescript
    • node.js
  • Element-UI
  • Apache ECharts
  • 数据结构
  • HTTP协议
  • HTTPS协议
  • 计算机网络
  • Linux常用命令
  • Windows常用命令
  • SQL数据库

    • MySQL
    • MySQL速查
  • NoSQL数据库

    • Redis
    • ElasticSearch
  • 数据库

    • MyBatis
    • MyBatis-Plus
  • 消息中间件

    • RabbitMQ
  • 服务器

    • Nginx
  • Spring框架

    • Spring6
    • SpringMVC
    • SpringBoot
    • SpringSecurity
  • SpringCould微服务

    • SpringCloud基础
    • 微服务之DDD架构思想
  • 日常必备

    • 开发常用工具包
    • Hutoll工具包
    • IDEA常用配置
    • 开发笔记
    • 日常记录
    • 项目部署
    • 网站导航
    • 产品学习
    • 英语学习
  • 代码管理

    • Maven
    • Git教程
    • Git小乌龟教程
  • 运维工具

    • Docker
    • Jenkins
    • Kubernetes
  • 算法笔记

    • 算法思想
    • 刷题笔记
  • 面试问题常见

    • 十大经典排序算法
    • 面试常见问题集锦
关于
GitHub (opens new window)
首页
  • Java 基础

    • JavaSE
    • JavaIO
    • JavaAPI速查
  • Java 高级

    • JUC
    • JVM
    • Java新特性
    • 设计模式
  • Web 开发

    • Servlet
    • Java网络编程
  • Web 标准

    • HTML
    • CSS
    • JavaScript
  • 前端框架

    • Vue2
    • Vue3
    • Vue3 + TS
    • 微信小程序
    • uni-app
  • 工具与库

    • jQuery
    • Ajax
    • Axios
    • Webpack
    • Vuex
    • WebSocket
    • 第三方登录
  • 后端与语言扩展

    • ES6
    • Typescript
    • node.js
  • Element-UI
  • Apache ECharts
  • 数据结构
  • HTTP协议
  • HTTPS协议
  • 计算机网络
  • Linux常用命令
  • Windows常用命令
  • SQL数据库

    • MySQL
    • MySQL速查
  • NoSQL数据库

    • Redis
    • ElasticSearch
  • 数据库

    • MyBatis
    • MyBatis-Plus
  • 消息中间件

    • RabbitMQ
  • 服务器

    • Nginx
  • Spring框架

    • Spring6
    • SpringMVC
    • SpringBoot
    • SpringSecurity
  • SpringCould微服务

    • SpringCloud基础
    • 微服务之DDD架构思想
  • 日常必备

    • 开发常用工具包
    • Hutoll工具包
    • IDEA常用配置
    • 开发笔记
    • 日常记录
    • 项目部署
    • 网站导航
    • 产品学习
    • 英语学习
  • 代码管理

    • Maven
    • Git教程
    • Git小乌龟教程
  • 运维工具

    • Docker
    • Jenkins
    • Kubernetes
  • 算法笔记

    • 算法思想
    • 刷题笔记
  • 面试问题常见

    • 十大经典排序算法
    • 面试常见问题集锦
关于
GitHub (opens new window)
npm

(进入注册为作者充电)

  • 快速入门

  • 克隆

  • 类型转换

  • 日期时间

  • IO流相关

  • 工具类

  • 语言特性

  • JavaBean

  • 集合类

  • Map

  • Codec编码

  • 文本操作

  • 注解

  • 比较器

  • 异常

  • 数学

  • 线程和并发

  • 图片

  • 网络

  • 源码编译

  • 配置文件

  • 日志

  • 缓存

  • JSON

  • 加密解密

  • DFA查找

  • HTTP客户端

  • 定时任务

  • 扩展

    • Servlet 工具类 - `ServletUtil`
    • 二维码工具 - `QrCodeUtil`
    • 邮件工具 - `MailUtil`
    • Cglib 工具 - `CglibUtil`
    • Emoji 工具 - `EmojiUtil`
      • 依赖引入
      • 1. 将 Emoji 字符转换为别名(Alias)
      • 2. 将别名转换为 Emoji 字符
      • 3. 将 Emoji 转换为 HTML 表现形式
      • 4. 其他常用方法
      • 5. 实际开发中的应用场景
    • FTP 客户端封装 - `Ftp`
    • 简易FTP服务器 - `SimpleFtpServer`
    • SFTP封装 - `Sftp`
    • Jsch工具 - `JschUtil`
    • Spring工具 - `SpringUtil`
    • 中文分词封装 - `TokenizerUtil`
    • 160压缩封装 - `CompressUtil`
    • 拼音工具 - `PinyinUtil`
    • 表达式引擎封装 - `ExpressionUtil`
    • 模板引擎封装 - `TemplateUtil`
  • 切面

  • 脚本

  • Office文档操作

  • 系统调用

  • 图形验证码

  • 网络Socket

  • JWT

  • Hutoll
  • 扩展
scholar
2024-08-20
目录

Emoji 工具 - EmojiUtil

# Emoji 工具 - EmojiUtil


简介

EmojiUtil 是 Hutool 在 4.2.1 版本之后引入的一个工具类,专门用于处理数据中的 Emoji 表情字符。考虑到 MySQL 等数据库的普通 UTF-8 编码并不支持 Emoji(只有 utf8mb4 支持),因此对数据中的 Emoji 字符进行转换和清理变得非常重要。EmojiUtil 基于 emoji-java 库封装,提供了便捷的 Emoji 处理功能。


# 依赖引入

在项目中使用 EmojiUtil 时,需要先引入 emoji-java 依赖:

<dependency>
    <groupId>com.vdurmont</groupId>
    <artifactId>emoji-java</artifactId>
    <version>4.0.0</version>
</dependency>
1
2
3
4
5

提示:请根据项目需求选择合适的版本,确保与 Hutool 的版本兼容。


# 1. 将 Emoji 字符转换为别名(Alias)

EmojiUtil.toAlias 方法用于将 Emoji 字符转换为别名形式。别名通常以 : 包围,例如将 😄 转换为 :smile:,这样便于在不支持 Emoji 的环境中存储和展示。

示例:将 Emoji 转换为别名

import cn.hutool.extra.emoji.EmojiUtil;

public class EmojiUtilExample {
    public static void main(String[] args) {
        // 将 Emoji 转换为别名形式
        String alias = EmojiUtil.toAlias("😄");

        // 输出结果为 ":smile:"
        System.out.println("别名形式: " + alias);
    }
}
1
2
3
4
5
6
7
8
9
10
11

代码解析:

  • EmojiUtil.toAlias(String emoji):将传入的 Emoji 字符转换为别名。
  • 返回值为转换后的字符串,例如 :smile:。

适用场景:

  • 在数据库或文件系统中存储不支持 Emoji 的字符时,可以先转换为别名再进行存储,方便后续处理和还原。

# 2. 将别名转换为 Emoji 字符

EmojiUtil.toUnicode 方法用于将别名形式的 Emoji 转换为对应的 Emoji 字符。例如,将 :smile: 转换为 😄。

示例:将别名转换为 Emoji 字符

import cn.hutool.extra.emoji.EmojiUtil;

public class EmojiUtilExample {
    public static void main(String[] args) {
        // 将别名转换为 Emoji 字符
        String emoji = EmojiUtil.toUnicode(":smile:");

        // 输出结果为 "😄"
        System.out.println("Emoji 字符: " + emoji);
    }
}
1
2
3
4
5
6
7
8
9
10
11

代码解析:

  • EmojiUtil.toUnicode(String alias):将别名形式转换为 Emoji 字符。
  • 返回值为转换后的 Emoji 字符,例如 😄。

适用场景:

  • 在读取存储的别名数据时,可以使用该方法将其转换回原始的 Emoji 字符,便于展示和进一步处理。

# 3. 将 Emoji 转换为 HTML 表现形式

EmojiUtil.toHtml 方法用于将字符串中的 Emoji 转换为 HTML 编码形式,通常用于在 Web 环境中展示 Emoji。

示例:将 Emoji 转换为 HTML 编码

import cn.hutool.extra.emoji.EmojiUtil;

public class EmojiUtilExample {
    public static void main(String[] args) {
        // 将 Emoji 转换为 HTML 表现形式
        String html = EmojiUtil.toHtml("😄");

        // 输出结果为 "&#128516;"
        System.out.println("HTML 表现形式: " + html);
    }
}
1
2
3
4
5
6
7
8
9
10
11

代码解析:

  • EmojiUtil.toHtml(String emoji):将传入的 Emoji 转换为 HTML 表现形式。
  • 返回值为 HTML 编码后的字符串,例如 &#128516;。

适用场景:

  • 在 Web 页面中展示 Emoji 时,可以使用 HTML 编码确保所有浏览器都能正确渲染 Emoji。

# 4. 其他常用方法

  • EmojiUtil.containsEmoji(String str):判断字符串中是否包含 Emoji 字符。
  • EmojiUtil.removeAllEmojis(String str):移除字符串中的所有 Emoji 字符。

这些方法可以帮助开发者在处理带有 Emoji 的数据时更加灵活、精准。


# 5. 实际开发中的应用场景

  1. 数据存储与展示:在数据库或日志系统中存储包含 Emoji 的数据时,可以先将其转换为别名,便于后续处理和还原。
  2. 跨平台数据传输:在平台或应用之间传输数据时,使用别名或 HTML 编码可以确保 Emoji 的完整性。
  3. 文本过滤:在用户提交内容时,可以过滤或移除其中的 Emoji,确保数据的规范性。

总结

EmojiUtil 是一个功能丰富且易于使用的工具类,帮助开发者在各种环境中轻松处理 Emoji。它的使用场景广泛,尤其在数据存储、文本处理、跨平台传输等领域,提供了便捷的解决方案。配合 Hutool 提供的其他工具,开发者可以更高效地完成日常开发任务。

编辑此页 (opens new window)
上次更新: 2024/12/28, 18:32:08
Cglib 工具 - `CglibUtil`
FTP 客户端封装 - `Ftp`

← Cglib 工具 - `CglibUtil` FTP 客户端封装 - `Ftp`→

Theme by Vdoing | Copyright © 2019-2025 程序员scholar
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式