在MySQL数据库中插入非英语文本时进行JSP编码

在MySQL数据库中插入非英语文本时进行JSP编码,第1张

在MySQL数据库中插入非英语文本时进行JSP编码

当我直接通过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-如何正确获取字符?


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/5500185.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-12-12
下一篇2022-12-12

发表评论

登录后才能评论

评论列表(0条)

    保存