我正在使用带有 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();
}
最佳答案
有问题的表/数据库是否设置为存储这些 unicode 值?您在连接字符串中设置的字符集仅控制数据在客户端和服务器之间传输的方式。如果该列无法存储该数据,您最终会得到损坏的数据。
关于java - 如何使用servlet在mysql中保存表情符号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45969562/