开发者社区> 问答> 正文

Java Web中数据从前端输入到插入数据库哪些地方需要考虑字符编码?

蛮大人123 2016-02-29 14:23:33 1128

目前考虑到的有三个地方需要设置字符编码:
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");
数据库:
screenshot
但最终插入数据库时还是乱码了(正常显示的数据是通过workbench插入的,乱码的是jdbc插入的):
screenshot
两个问题:

  1. 是不是有一些需要设置字符编码的地方我给忽略了,比如Tomcat,JVM的编码?
  2. PHP会有类似的坑吗?
前端开发 Java 关系型数据库 MySQL 数据库连接 应用服务中间件 PHP 数据库
分享到
取消 提交回答
全部回答(3)
  • 一生有你llx
    2019-07-17 18:50:16

    问题应该是出在Tomcat身上。浏览器请求传到Tomcat容器的时候还会经历一次编码转换,而Tomcat7.0对请求的默认编码字符集是ISO8859-1(还没找到Tomcat的官方文档来支持这一观点),所以解决方法就是在java代码里对请求再次进行编码转换。其中有两种处理方式:
    1.
    对参数值的字符串进行编码转换。
    new String(request.getParameter("name").getByte("ISO-8859-1"),"UTF-8");
    2.
    对进入容器的所有请求进行编码转换。这个方式需要配置一个过滤器

    public void doFilter(ServletRequest request, ServletResponse response,

        FilterChain chain) throws IOException, ServletException {

    request.setCharacterEncoding("utf-8");
    chain.doFilter(request, response);
    }

    0 0
  • nothingfinal
    2019-07-17 18:50:16

    问题应该是出在Tomcat身上。浏览器请求传到Tomcat容器的时候还会经历一次编码转换,而Tomcat7.0对请求的默认编码字符集是ISO8859-1(还没找到Tomcat的官方文档来支持这一观点),所以解决方法就是在java代码里对请求再次进行编码转换。其中有两种处理方式:
    1.
    对参数值的字符串进行编码转换。
    new String(request.getParameter("name").getByte("ISO-8859-1"),"UTF-8");
    2.
    对进入容器的所有请求进行编码转换。这个方式需要配置一个过滤器

    public void doFilter(ServletRequest request, ServletResponse response,

            FilterChain chain) throws IOException, ServletException {
    request.setCharacterEncoding("utf-8");
    chain.doFilter(request, response);

    }

    0 0
  • 蛮大人123
    2019-07-17 18:50:16

    问题应该是出在Tomcat身上。浏览器请求传到Tomcat容器的时候还会经历一次编码转换,而Tomcat7.0对请求的默认编码字符集是ISO8859-1(还没找到Tomcat的官方文档来支持这一观点),所以解决方法就是在java代码里对请求再次进行编码转换。其中有两种处理方式:
    1.
    对参数值的字符串进行编码转换。
    new String(request.getParameter("name").getByte("ISO-8859-1"),"UTF-8");
    2.
    对进入容器的所有请求进行编码转换。这个方式需要配置一个过滤器

    public void doFilter(ServletRequest request, ServletResponse response,
                FilterChain chain) throws IOException, ServletException {
        request.setCharacterEncoding("utf-8");
        chain.doFilter(request, response);
    }
    0 0
添加回答
+ 订阅

分享数据库前沿,解构实战干货,推动数据库技术变革

推荐文章
相似问题