JavaEE中向数据库写入数据乱码的问题

1.首先查看数据库的设置:以mysql为例


在mysql的安装目录下的my.in文件内i修改设置

2.在servlet中设置

            request.setCharacterEncoding("utf-8");
     response.setCharacterEncoding("utf-8");

3.将jsp页面的表单提交方式更改为post

自从Tomcat5.x开始,GET和POST方法提交的信息,Tomcat采用了不同的方式来处理编码,对于POST请求,Tomcat会仍然使用request.setCharacterEncoding方法所设置的编码来处理,如果未设置,则使用默认的iso-8859-1编码。而GET请求则不同,Tomcat对于GET请求并不会考虑使用request.setCharacterEncoding方法设置的编码,而会永远使用iso-8859-1编码。
解决办法如下:


      1.配置tomcat的配置文件server.xml里这句:
           <Connector URIEncoding="GB2312" 
                 port="8080"   maxHttpHeaderSize="8192"
               maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
               enableLookups="false" redirectPort="8443" acceptCount="100"
               connectionTimeout="20000" disableUploadTimeout="true" />


                 加上这句:URIEncoding="GB2312"
     2.使用String name=new String(request.getParameter("name").getBytes("ISO-8859-1"),"GB2312");转化编码
推荐使用第二种方式。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值