java 乱码总结

1、文件乱码处理 html


1、文件默认编码:默认使用项目的默认编码
右击文件->Properties->Resource->Text file encoding java


2JSP文件编码:因为JSP要翻译为Servlet mysql


   <%@ page language="java" pageEncoding="utf-8"%> web




2、浏览器与服务器传输数据乱码处理 sql


1浏览器端编码,通常由服务器端告诉浏览器如何解码数据: 数据库


1.1Servlet apache


    response.setContentType("text/html; charset=UTF-8"); 或者  response.setCharacterEncoding(“UTF-8”); 浏览器


1.2JSP tomcat


    <%@ page language="java" contentType="text/html; charset=utf-8" %> 服务器


1.3、通用


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


1.4Javascript传参乱码


在浏览器端对要传递的中文参数进行编码处理.代码以下
       xmlhttp.open("POST",url,true); //请求参数初始化
       xmlhttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); //由于请求方式为POST,因此这里要设置请求头.(若是请求方式为GET,此句代码能够省略)
       xmlhttp.send("name="+encodeURI(encodeURI("星期日"))); //向服务器端发送参数
在服务器端代码:


页面jsp保证是utf-8编码


<%@ page contentType="text/html; charset=utf-8"%>


接受中文参数
       PrintWriter out = response.getWriter(); //获得response的输出流对象 
       String name1 = request.getParameter("name"); //获得KEY"name"的请求参数 
       String name = URLDecoder.decode(name1,"utf-8"); //对获得的参数进行解码 
       out.print(name); //向浏览器端发送数据


1.5热连接传参乱码


在传参的jsp对中文进行编码:href="new.jsp?name=java.net.URLEncoder.encode("连接")";


在接受的jsp对中文进行转码:String str = URLDecoder.decode(request.getParameter("name "), "utf-8");


注:浏览器编码能够由咱们手工修改,但最后不要这样,通常让浏览器自动选择便可。




2、服务器端编码,将客户端传过来的数据进行解码: 
浏览器默认使用ISO-8859-1进行编码数据,而后将数据传输到服务器,所以咱们默认只须要将浏览器发送过来的数据转换为咱们须要的编码便可。


2.1、最简单方式:


    String username = request.getParameter(“username”);


    username = new String(username.getBytes("ISO-8859-1“), "UTF-8");


2.2、比较好的解决方案
// 
必须在获取参数以前,调用以下方法先解码 request.setCharacterEncoding(“UTF-8”);


String username = request.getParameter(“username”);



2.3、比较通用方案:在一个Filter中更改全部请求的编码方式:


A、在src中添加filter来设置编码格式是中文,filter类能够在tomcat的包里面:apache-tomcat-6.0.16.zip\apache-tomcat-6.0.16\webapps\examples\WEB-INF\classes\filters下面,SetCharacterEncodingFilter.java文件 
B、在web.xml中配置
filter,具体配置以下页:


<filter>

       <filter-name>Set Character Encoding</filter-name>

        <filter-class>filters.SetCharacterEncodingFilter</filter-class>

        <init-param><param-name>encoding</param-name>

       <param-value>utf-8</param-value></init-param>

</filter>

<filter-mapping>

        <filter-name>Set Character Encoding</filter-name>

        <url-pattern>/*</url-pattern>

</filter-mapping>


2.4GET提交方式中文乱码解决


经过修改request.setCharacterEncoding(“UTF-8”);只能解决POST提交方式的请求编码,对GET无效。


A、最简单解决方案:
解决方案再也不须要任何额外配置(如filter) TOMCAT默认ISO-8859-1 所以能够设置默认编码为UTF-8解决,在conf\server.xml文件中设置以下 <Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" URIEncoding=”UTF-8”/>


B、在tomcat4以后,能够经过以下配置来解决中文乱码,但必须配置filter 
在conf\server.xml文件中设置以下 <Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" useBodyEncodingForURI=“true”/> 
而后request.setCharacterEncoding(“UTF-8”)也可解决GET乱码


3Java与数据库之间的乱码:
  大部分数据库都支持以unicode编码方式,因此解决Java与数据库之间的乱码问题比较明智的方式是直接使用unicode编码与数据库交互。不少数据库驱动自动支持unicode,如Microsoft的SQLServer驱动。其余大部分数据库驱动,能够在驱动的url参数中指定,如mysql驱动:

jdbc:mysql://localhost/MYAPPS?useUnicode=true&characterEncoding=GBK


或者使用JAVA程序,修改编码,程序以下:


public class Convert {

  public static String ISOtoGB(String iso){
  String gb;
  try{
    if(iso.equals("") || iso == null){
      return "";
    }
    else{
      iso = iso.trim();
      gb = new String(iso.getBytes("ISO-8859-1"),"GB2312");
      return gb;
    }
  }
  catch(Exception e){
    System.err.print("
编码转换错误:"+e.getMessage());
    return "";
    }
  }
}


4Java与文件/流之间的乱码:
  Java读写文件最经常使用的类是FileInputStream / FileOutputStream和FileReader / FileWriter。其中FileInputStream和FileOutputStream是基于字节流的,经常使用于读写二进制文件。读写字符文件建议使用基于字符的FileReader和FileWriter,省去了字节与字符之间的转换。但这两个类的构造函数默认使用系统的编码方式,若是文件内容与系统编码方式不一致,可能会出现乱码。在这种状况下,建议使用FileReader和FileWriter的父类:InputStreamReader / OutputStreamWriter,它们也是基于字符的,但在构造函数中能够指定编码类型:InputStreamReader(InputStream in, Charset cs) 和OutputStreamWriter(OutputStream out, Charset cs)。

相关文章
相关标签/搜索