开发者社区> 问答> 正文

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");
数据库:
screenshot
但最终插入数据库时还是乱码了(正常显示的数据是通过workbench插入的,乱码的是jdbc插入的):
screenshot
两个问题:

  1. 是不是有一些需要设置字符编码的地方我给忽略了,比如Tomcat,JVM的编码?
  2. PHP会有类似的坑吗?

展开
收起
蛮大人123 2016-02-29 14:23:33 3354 0
3 条回答
写回答
取消 提交回答
  • 专注物联网

    问题应该是出在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);
    }

    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);

    }

    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);
    }
    2019-07-17 18:50:16
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
Vue.js 在前端服务化上的探索与实践 立即下载
阿里文娱大前端技术实践 立即下载
前端代码是怎样智能生成的 立即下载