request.getParameter(“参数名”) 中文乱码解决方法 |
您所在的位置:网站首页 › utf8中文乱码原因 › request.getParameter(“参数名”) 中文乱码解决方法 |
尽量用post提交,不要用问号拼接参数的方式,就不会乱码了
原文:http://blog.csdn.net/wzygis/article/details/50964864
在Java 开发中,如果框架搭建的不完善或者初学者在学习过程中,出现中文乱码是经常的事儿(哈。谁让发明Java语言的不是中国人呢) 今天跟大家分享几个解决java Web开发中,request.getParameter()获取URL中文参数乱码的解决办法 解决问题,先要研究问题,URL传中文参数为什么会出现乱码? 原因:Http请求传输时将url以ISO-8859-1编码,服务器收到字节流后默认会以ISO-8859-1编码来解码成字符流(造成中文乱码) 解决办法:我们需要把request.getParameter(“参数名”)获取到的字符串先用ISO-8859-1编码成字节流,然后再将其用utf-8解码成字符流 代码: String str = new String(request.getParameter("参数名").getBytes("iso-8859-1"), "utf-8"); 这是通过转码的方式处理乱码问题,我们也可以通过Tomcat配置文件,设置URL编码集(URIEncoding)设置编码,这种方法也是一劳永逸的, 修改Tomcat/conf 目录下 server.xml
重点在 userBodyEncodingForURI 和 URIEncoding 这两个属性 下面来解释一下这两个属性的意义 useBodyEncodingForURI参数表示是否用request.setCharacterEncoding参数对URL提交的数据和表单中GET方式提交的数据进行重新编码,在默认情况下,该参数为false。 URIEncoding参数指定对所有GET方式请求进行统一的重新编码(解码)的编码。 URIEncoding和useBodyEncodingForURI区别是, URIEncoding是对所有GET方式的请求的数据进行统一的重新编码, 而useBodyEncodingForURI则是根据响应该请求的页面的request.setCharacterEncoding参数对数据进行的重新编码,不同的页面可以有不同的重新编码的编码。
原文:http://blog.csdn.net/lixuanshengchao/article/details/51521005 今天做一个项目遇到一个问题,在myeclipse里面调试的时候,里面的数据不是乱码,但是插入到MySQL数据库后就是乱码了。mysql的my.ini文件设置的是utf8,这些都没得问题,但是插入数据库还是乱码。 最后还是找到了解决办法。在连接数据库类里面的url参数设置如下: jdbc:mysql://localhost:3306/zhuojh?useUnicode=true&characterEncoding=UTF-8 在后面加上这两个参数。就不是乱码了。 driverClassName=com.mysql.jdbc.Driverurl=jdbc:mysql://localhost:3306/enterprise?useUnicode=true&characterEncoding=UTF-8username=rootpassword=brozerinitialSize=5maxIdle=10maxTotal=50maxWaitMillis=5000minIdle=5
页面加上编码设置
原文:http://blog.csdn.net/cc_yy_zh/article/details/51559742 客户端向服务器端发送信息,如果发送的编码和服务器端接收的编码不一样,使用request.getParameter()方法获取的表单信息会产生乱码。客户端接收服务器的响应信息,如果响应编码与客户浏览器的编码不一致时,会造成中文乱码显示。 为了解决中文正常显示,可以采取以下方案。 (1)post方式提交表单 a>设置页面的编码 在jsp或HTML页面中,有时会涉及编码的定义,可使用统一编码,例如GBK或UTF-8. b>设置表单提交方式在页面中,将 标记的method属性值设置为post,该属性默认为get,get方式会将表单信息采取特殊编码,然后借助于URL发送给服务器。 c>设置服务器接收编码 在使用request.getParameter()方式接收客户表单信息之前,设置接收编码,编码与页面保持一致。request.setCharacterEncoding(“UTF-8”); 使用setCharacterEncoding()方法指定编码后,可以通过getParameter()方法按指定编码获得客户信息,如果不指定,则默认使用ISO-8859-1编码。 下面比较强硬了 String str = new String(request.getParameter(“参数名”).getBytes(“iso-8859-1”), “utf-8”);
原文:http://www.cnblogs.com/tom-plus/p/5701741.html web项目存数据到数据库,中文乱码,解决过程 first:排查原因: 打断点,查看到底是在执行存数据库操作之前就已经乱码了,还是存数据库操作后乱码的。 前者解决方案: 在web.xml里面加上: encodingFilter org.springframework.web.filter.CharacterEncodingFilter true encoding UTF-8 encodingFilter /*在配置jdbc数据源的时候加上: jdbc:mysql://127.0.0.1:3306/logistics?useUnicode=true;characterEncoding=UTF-8存数据库操作后乱码,解决方案:登录数据库,执行如下sql: show variables like 'character%'; 结果: | character_set_client | utf8 | | character_set_connection | utf8 | | character_set_database | latin1 | | character_set_filesystem | binary | | character_set_results | utf8 | | character_set_server | latin1 | | character_set_system | utf8 |
说明在安装数据库的时候,character_set_database,character_set_server编码格式设置错误。 解决: 找到mysql安装路径下的my.cnf文件在[mysqld]下添加如下两行: character_set_server=utf8 init_connect='SET NAMES utf8' 再次查看,问题解决: | character_set_client | utf8 | | character_set_connection | utf8 | | character_set_database | utf8 | | character_set_filesystem | binary | | character_set_results | utf8 | | character_set_server | utf8 | | character_set_system | utf8
看完打开支付宝扫一扫领个红包吧! ![]() |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |