当我直接通过JDBC(不使用Ajax调用)插入非英语字符时,它显示为“ ????”。 在数据库中。
只有当双方都完全意识到双方的字符编码差异时,才会发生这种情况。任何未在另一侧使用的字符编码覆盖的字符都将被问号替换
?。否则,您会看到Mojibake的。
在这种特定情况下,这些方面是Java方面和数据库方面,而JDBC驱动程序作为中介。要解决此问题,您需要告诉JDBC驱动程序这些字符的编码方式。您可以通过
useUnipre=true&characterEncoding=UTF-8在JDBC连接URL中设置参数来实现。
jdbc:mysql://localhost:3306/dbname?useUnipre=true&characterEncoding=UTF-8
然后,根据您如何将参数从客户端发送到服务器,您可能还需要修复请求编码。考虑到您在删除时看到Mojibake的事实
request.setCharacterEncoding("UTF-8"),因此您正在使用POST。所以那部分很好。对于这种情况,如果使用GET发送参数,则需要在服务器端配置URI编码。目前尚不清楚您使用的是哪台服务器,但是例如对于Tomcat,只需按以下步骤编辑
<Connector>条目即可
/conf/server.xml:
<Connector ... URIEncoding="UTF-8">
也可以看看:
- Unipre-如何正确获取字符?



