首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >UTF-8编码的问题;我存储的内容以及在用户界面中看到的内容。

UTF-8编码的问题;我存储的内容以及在用户界面中看到的内容。
EN

Stack Overflow用户
提问于 2018-10-11 16:52:46
回答 1查看 31关注 0票数 1

我在utf8编码方面遇到了麻烦。它正确地存储在数据库中,但在UI上却没有完全相同。就像在数据库中保存的,我得到了圣保罗的UI。我做错了什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-10-11 18:38:06

在处理MySQL数据库中的非ASCII字符时,使用utf8mb4而不是utf8更安全。MySQL utf8不是真正的utf8,因为它只使用最多3个字节来存储Unicode字符,这是不正确的,因为有些Unicode字符甚至需要4个字节,比如表情符号字符,而且可能是其他字节。

一旦您在MySQL上选择的编码正确,您可能仍会遇到问题,原因如下:

  1. 您需要确保jdbc连接字符串是正确的,并设置 其中的这个参数,useUnicode=true
  2. 在返回包含unicode字符的响应时,请确保正确设置响应编码,如下所示, httpServletResponse.setContentType("text/json;字符集=UTF-8“;

如果不这样做,您的响应将显示意想不到的字符。

  1. 在客户端读取响应后,请确保使用UTF8编码,而不是默认编码,后者可能是特定于平台的编码,如CP1252等。

如果您在上述三点中做错了任何事情,您将不会看到预期的unicode字符。有时候,当我们正确地做好每件事,并且在上面的任何一点上都犯了一个错误的时候,这真的很令人沮丧。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52765279

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档