Java Web中数据从前端输入到插入数据库哪些地方需要考虑字符编码?-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

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

2016-02-29 14:23:33 2717 3

目前考虑到的有三个地方需要设置字符编码:
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会有类似的坑吗?
取消 提交回答
全部回答(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
添加回答
相关问答

20

回答

【大咖问答】对话PostgreSQL 中国社区发起人之一,阿里云数据库高级专家 德哥

阿里ACE 彭飞 2019-07-10 09:36:10 1223071浏览量 回答数 20

170

回答

惊喜翻倍:免费ECS+免费环境配置~!(ECS免费体验6个月活动3月31日结束)

豆妹 2014-10-29 17:52:21 232249浏览量 回答数 170

145

回答

【新手入门】云服务器linux使用手册

fanyue88888 2012-11-26 17:14:18 159399浏览量 回答数 145

8

回答

OceanBase 使用动画(持续更新)

mq4096 2019-02-20 17:16:36 340459浏览量 回答数 8

119

回答

OSS存储服务-客户端工具

newegg11 2012-05-17 15:37:18 301011浏览量 回答数 119

24

回答

阿里云开放端口权限

xcxx 2016-07-20 15:03:33 657974浏览量 回答数 24

39

回答

安全组详解,新手必看教程

我的中国 2017-11-30 15:23:46 262871浏览量 回答数 39

21

回答

请教一下数据量有100万条左右要什么配置?

易网网络 2013-03-27 15:18:02 193529浏览量 回答数 21

251

回答

阿里云LNAMP(Linux + Nginx + Apache + MySQL + PHP)环境一键安装脚本

云代维 2014-02-14 15:26:06 309327浏览量 回答数 251

2

回答

区域选择帮助

fanyue88888 2012-12-07 15:54:30 205400浏览量 回答数 2
+关注
蛮大人123
我说我不帅他们就打我,还说我虚伪
0
文章
7733
问答
问答排行榜
最热
最新
相关电子书
更多
OceanBase 入门到实战教程
立即下载
阿里云图数据库GDB,加速开启“图智”未来.ppt
立即下载
实时数仓Hologres技术实战一本通2.0版(下)
立即下载