java - 如何使用servlet在mysql中保存表情符号

标签 java mysql servlets

我正在使用带有 mysql 连接器 5.1.44 的 servlet 连接到 mysql 数据库。

Connection conn = DriverManager.getConnection(Utils.DBURL+"/"+Utils.DBName+"?useUnicode=true&characterEncoding=utf8mb4&", Utils.DBUserName, Utils.DBPassword);

这适用于多语言输入,但在尝试保存表情符号时,它最终只保存了“??”。 我该怎么做才能仅使用 servlet 来保存表情符号?

小服务程序代码

protected void processRequest(HttpServletRequest request, HttpServletResponse response)
        throws ServletException, IOException{
response.setContentType("application/json");
request.setCharacterEncoding("UTF-8");
String content = request.getParameter("content");
Class.forName("com.mysql.jdbc.Driver");
        Connection conn = 
DriverManager.getConnection(Utils.DBURL+"/"+Utils.DBName+"?
useUnicode=true&characterEncoding=utf8mb4&", Utils.DBUserName, 
Utils.DBPassword);
PreparedStatement stmt = conn.prepareStatement("INSERT INTO "
                            + "`feed`(`content`)"
                            + " VALUES (?)");
stmt.setString(1, content);
stmt.executeUpdate();
}

最佳答案

有问题的表/数据库是否设置为存储这些 un​​icode 值?您在连接字符串中设置的字符集仅控制数据在客户端和服务器之间传输的方式。如果该列无法存储该数据,您最终会得到损坏的数据。

关于java - 如何使用servlet在mysql中保存表情符号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45969562/

相关文章:

java - 将字符串加密从 Ruby 迁移到 Java

shell - ProcessBuilder.start() 返回 0 但不执行 shell 脚本

java - 将每周电子邮件发送/时事通讯与 Spring 框架集成

java - 本地和远程连接池,Java DBCP

java - 如何运行包含 clojure 和 java 代码编译的类文件的 jar 文件。 java文件包含main方法

mysql - 加载 enwiki-latest-categorylinks.sql 到 mysql

php - 对特定 MySQL 表列求和并将结果写入其他列

java - 改造 Android 在 MySQL 中添加新行

java - 使用 java servlet 将数据从一个 html 页面传递到另一页面

Phusion Passenger Server 中的 Java Web 应用程序