Java Web中数据从前端输入到插入数据库,哪些地方需要考虑字符编码?
目前考虑到的有三个地方需要设置字符编码:
JSP页面:<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
JDBC获取连接时:
DriverManager.getConnection("jdbc:mysql://localhost:3306/developerdb?useUnicode=true&characterEncoding=utf8", "developer", "developer");
数据库:
但最终插入数据库时还是乱码了(正常显示的数据是通过workbench插入的,乱码的是jdbc插入的):
两个问题:
1. 是不是有一些需要设置字符编码的地方我给忽略了,比如Tomcat,JVM的编码?
2. PHP会有类似的坑吗?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
一、如果是mysql的话,安装时如果没有选择编码,则需要修改mysql安装路径下配置文件中的编码。
二、中文的话需要处理decode和encode,js或者后台。
问题解决了。
原因应该是出在Tomcat身上。浏览器请求传到Tomcat容器的时候还会经历一次编码转换,而Tomcat7.0对请求的默认编码字符集是ISO8859-1(还没找到Tomcat的官方文档来支持这一观点),所以解决方法就是在java代码里对请求再次进行编码转换。其中有两种处理方式:
对参数值的字符串进行编码转换。
new String(request.getParameter("name").getByte("ISO-8859-1"),"UTF-8");
对进入容器的所有请求进行编码转换。这个方式需要配置一个过滤器
特别感谢 @Dont @Honwhy
1.jsp文件以及.java文件自身的编码,建议用Notepad++看一下。Eclipse设置中搜索Content Type把.java .jsp的编码改为UTF-8
2.
<%@ page language="java" pageEncoding="UTF-8"%>
3.楼主的数据库链接字符串 应该为characterEncoding=UTF-8 而不是utf8。数据库和java中有所不同。传送门:
MySQL官方 mysql-connector-j驱动包字符串详解
4.数据库,以及对应表中相应字段的编码,都要为utf8
当然还可能有jvm虚拟机,tomcat,一般情况下没事……
如果赞同请采纳。如有错误请指出。谢谢。
如果食用spring,可以通过在web.xml中注册Encoding Filter解决。