java request获取参数乱码_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.Driver

url=jdbc:mysql://localhost:3306/enterprise?useUnicode=true&characterEncoding=UTF-8

username=root

password=brozer

initialSize=5

maxIdle=10

maxTotal=50

maxWaitMillis=5000

minIdle=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

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

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值