在 Web 应用或移动App中,我们经常需要显示表情符号。但表情符号包含许多非ASCII字符,不能直接在文本中传输,所以通常会转换为HTML实体编码进行传输和存储,如常见的微笑表情“:😊:”会编码为“😊”。但是后续读取网络返回的文本内容时,如果不对这些HTML实体进行解码,就会直接输出类似“😊”的字符串,导致表情显示为乱码的问题。
问题原因:
HTML实体编码可以避免表情和其他特殊符号在网络传输和存储中出现错误或丢失,所以通常会在文本中包含大量这种编码。但我们在拿到文本内容后,需要进行解码才能显示原始的表情符号。直接显示HTML编码字符串是因为没有进行实体解码导致的。
解决思路:
要解决这个问题,我们需要在获得文本内容后,对其中的HTML实体编码进行解码,转换回对应的Unicode字符,才能正确显示表情。主要的技术方案有:
String html = EntityUtils.toString(response.getEntity(), "UTF-8");
String text = Jsoup.parse(html).text();
String html = EntityUtils.toString(response.getEntity(), "UTF-8");
String text = StringEscapeUtils.unescapeHtml4(html);
String text = html.replace("", "\ud83d\ude0a");
Pattern pattern = Pattern.compile("(\\d+);");
Matcher matcher = pattern.matcher(html);
while(matcher.find()){
String ch = Character.toString((char)Integer.parseInt(matcher.group(1)));
html = html.replace(matcher.group(), ch);
}