zoukankan      html  css  js  c++  java
  • 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

    <Connector URIEncoding="UTF-8" acceptCount="1500" connectionTimeout="20000" enableLookups="false" maxSpareThreads="100" maxThreads="1000" minSpareThreads="25" port="9082" protocol="HTTP/1.1" useBodyEncodingForURI="true"/>

    重点在 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

    页面加上编码设置

    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

    原文: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里面加上:

    <filter>
    <filter-name>encodingFilter</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <async-supported>true</async-supported>
    <init-param:>
    <param-name>encoding</param-name>
    <param-value>UTF-8</param-value>
    </init-param>
    </filter>
    <filter-mapping>
    <filter-name>encodingFilter</filter-name>
    <url-pattern>/*</url-pattern>
    </filter-mapping>
    在配置jdbc数据源的时候加上:
    jdbc:mysql://127.0.0.1:3306/logistics?useUnicode=true&amp;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        

     

  • 相关阅读:
    [离散数学II]2017.5.9
    mysql内连接、左连接、右连接
    Android平台介绍
    软技能(面试)1
    流程控制练习题
    函数:算法
    linux系统文件
    App测试需注意
    python-循环
    python-正则表达式
  • 原文地址:https://www.cnblogs.com/shihaiming/p/6898956.html
Copyright © 2011-2022 走看看