本文目錄一覽:
如何優化Java編程中的中文問題
具體解決辦法如下:
1、 針對直接在console上運行的類
對於這種情況,我們建議在程序編寫時,如果需要從用戶端接收用戶的可能含有中文的輸入或含有中文的輸出,程序中應該採用字符流來處理輸入和輸出,具體來說,應用以下面向字符型節點流類型:
對文件:FileReader,FileWrieter
其字節型節點流類型為:FileInputStream,FileOutputStream
對內存(數組):CharArrayReader,CharArrayWriter
其字節型節點流類型為:ByteArrayInputStream,ByteArrayOutputStream
對內存(字符串):StringReader,StringWriter
對管道:PipedReader,PipedWriter
其字節型節點流類型為:PipedInputStream,PipedOutputStream
同時,應該用以下面向字符型處理流來處理輸入和輸出:
BufferedWriter,BufferedReader
其字節型的處理流為:BufferedInputeStream,BufferedOutputStream
InputStreamReader,OutputStreamWriter
其字節型的處理流為:DataInputStream,DataOutputStream
其中InputStreamReader和InputStreamWriter用於將字節流按照指定的字符編碼集轉換到字符流,如:
InputStreamReader in = new InputStreamReader(System.in,”GB2312″);
OutputStreamWriter out = new OutputStreamWriter (System.out,”GB2312″);
例如:採用如下的示例JAVA編碼就達到了要求:
//Read.java
import java.io.*;
public class Read {
public static void main(String[] args) throws IOException {
String str = “/n中文測試,這是內部硬編碼的串”+”/ntest english character”;
String strin= “”;
BufferedReader stdin = new BufferedReader(new InputStreamReader(System.in,”gb2312″)); //設置輸入接口按中文編碼
BufferedWriter stdout = new BufferedWriter(new OutputStreamWriter(System.out,”gb2312″)); //設置輸出接口按中文編碼
stdout.write(“請輸入:”);
stdout.flush();
strin = stdin.readLine();
stdout.write(“這是從用戶輸入的串:”+strin);
stdout.write(str);
stdout.flush();
}}
同時,在編譯程序時,我們用以下方式來進行:
javac -encoding gb2312 Read.java
其運行結果如圖5所示:
如何優化Java編程中的中文問題?
圖5
2、 針對EJB類和不可以直接運行的支持類(如JavaBean類)
由於這種類它們本身被其它的類調用,不直接與用戶交互,故對這種類來說,我們的建議的處理方式是內部程序中應該採用字符流來處理程序內部的中文字符串(具體如上面一節中一樣),同時,在編譯類時用-encoding gb2312參數指示源文件是中文格式編碼的即可。
3、 針對Servlet類
針對Servlet,我們建議用以下方法:
在編譯Servlet類的源程序時,用-encoding指定編碼為GBK或GB2312,且在向用戶輸出時的編碼部分用response對象的setContentType(“text/html;charset=GBK”);或gb2312來設置輸出編碼格式,同樣在接收用戶輸入時,我們用request.setCharacterEncoding(“GB2312”);這樣無論我們的servlet類移植到什麼操作系統中,只有客戶端的瀏覽器支持中文顯示,就可以正確顯示。如下是一個正確的示例:
//HelloWorld.java
package hello;
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class HelloWorld extends HttpServlet
{
public void init() throws ServletException { }
public void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException
{
request.setCharacterEncoding(“GB2312”); //設置輸入編碼格式
response.setContentType(“text/html;charset=GB2312”); //設置輸出編碼格式
PrintWriter out = response.getWriter(); //建議使用PrintWriter輸出
out.println(“hr”);
out.println(“Hello World! This is created by Servlet!測試中文!”);
out.println(“hr”);
}
public void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException
{
request.setCharacterEncoding(“GB2312”); //設置輸入編碼格式
response.setContentType(“text/html;charset=GB2312”); //設置輸出編碼格式
String name = request.getParameter(“name”);
String id = request.getParameter(“id”);
if(name==null) name=””;
如何解決Java中的中文亂碼問題
對於Java,由於默認的編碼方式是UNICODE,所以用中文也易出問題,常見的解決是:
String s2 = new String(s1.getBytes(“ISO-8859-1”),”GBK”);
1、utf8解決JSP中文亂碼問題
一般說來在每個頁面的開始處,加入:
%@ page language=”java” contentType=”text/html; charset=UTF-8″
pageEncoding=”UTF-8″%
%@ page language=”java” contentType=”text/html; charset=UTF-8″
pageEncoding=”UTF-8″%
%
request.setCharacterEncoding(“UTF-8”);
%
◆charset=UTF-8的作用是指定JSP向客戶端輸出的編碼方式為“UTF-8”;
◆pageEncoding=”UTF-8″,為了讓JSP引擎能正確地解碼含有中文字符的JSP頁面,這在LINUX中很有效;
◆request.setCharacterEncoding(“UTF-8”);是對請求進行了中文編碼。
有時,這樣仍不能解決問題,還需要這樣處理一下:
String msg = request.getParameter(“message”);
String str=new String(msg.getBytes(“ISO-8859-1″),”UTF-8”);
out.println(st);
Java編碼時輸入漢字出現亂碼解決方法
java文件讀取的時候有中文就很出現亂碼,通常獲取到的文件中通常都是“iso8859-1”格式,需要轉換為“UTF-8”格式。
如:String str = new String(str.getByte(“iso8859-1”),”UTF-8″);進行下強制轉換後在進行讀取即可。
備註:通常格式有GBK、UTf-8、iso8859-1、GB2312,如果上面的強制轉換不成功,依次進行這些格式的嘗試,肯定是可以解決問題的。
在java中怎樣處理中文亂碼的問題?(有幾種處理方式)
讀取文件的時候如果是用的read方法(字節流),碰到中文輸出就是亂碼,然後存儲的時候設置下編碼為GBK或者是UTF-8形式即可,可以有效的解決亂碼問題。
可以通過BufferedReader 流的形式進行流緩存,之後通過readLine方法獲取到緩存的內容。
BufferedReader bre = null;
try {
String file = “D:/test/test.txt”;
bre = new BufferedReader(new FileReader(file));//此時獲取到的bre就是整個文件的緩存流
while ((str = bre.readLine())!= null) // 判斷最後一行不存在,為空結束循環
{
System.out.println(str);//原樣輸出讀到的內容
};
備註: 流用完之後必須close掉,如上面的就應該是:bre.close(),否則bre流會一直存在,直到程序運行結束。
可以通過“FileOutputStream”創建文件實例,之後過“OutputStreamWriter”流的形式進行存儲,舉例:
OutputStreamWriter pw = null;//定義一個流
pw = new OutputStreamWriter(new FileOutputStream(“D:/test.txt”),”GBK”);//確認流的輸出文件和編碼格式,此過程創建了“test.txt”實例
pw.write(“我是要寫入到記事本文件的內容”);//將要寫入文件的內容,可以多次write
pw.close();//關閉流
備註:文件流用完之後必須及時通過close方法關閉,否則會一直處於打開狀態,直至程序停止,增加系統負擔。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/229231.html