1.關於jsp(SUN企業級應用的首選)接收FORM參數的亂碼:
<%@ page contentType="text/html;charset=GB2312" %> <!--/*為了tomcat(一個很好用的JSP運行平台)4用jsp(SUN企業級應用的首選)產生中文亂碼問題,定義一個轉換函數getStr() !-->
<%!
public String getStr(String str){
try {String temp_p=str;
byte[] temp_t=temp_p.getBytes("ISO8859-1");
String temp=new String(temp_t);
return temp;
}
catch(Exception e){ }
return "NULL";
}
%>
<!---------------------The end ----------------------*/-->
2.關於Servlet接收Form參數的亂碼.
文件名:ThreeParams.java 內容如下:
package moreservlets;import java.io.*;import javax.servlet.*;import javax.servlet.http.*;public class ThreeParams extends HttpServlet { //定義一個函數getStr(),用來解決接收form參數亂碼問題 public String getStr(String str){ try{String temp_p=str; byte[] temp_t=temp_p.getBytes("ISO8859-1"); String temp=new String(temp_t); return temp; } catch(Exception e){ } return "NULL"; } //--接收form傳來的三個參數,並顯示。注意,第三個參數沒有轉換,可以用來對比. public void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException,ServletException { response.setContentType("text/html;charset=GB2312"); PrintWriter out =response.getWriter(); String docType= "<! DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 "+ "Transitional//EN">
"; out.println(docType+ "<HTML>
"+ "<BODY>
"+ getStr(request.getParameter("param1"))+"<BR>"+ getStr(request.getParameter("param2"))+"<BR>"+ request.getParameter("param3")+"<BR>"+ "<center><h1>你好,JAVA世界!!我是Servlet服務器小程序!!</H1></center>
"+ "</BODY></HTML>"); } }
3.如何處理用jConnect連接Sybase數據庫時中文亂碼的問題:
確保數據庫使用中文字符集,如 eucgb, utf8, cp936, 同時, 在 jconnect 編程時設定必要的連接屬性, 包括 charset (要求與數據庫保持一致) 和 jconnect_version.
例如:
jconnect 4.2:
jdbc:sybase:Tds:hostname:port/dbname?charset=eucgb&jconnect_version=4
jconnect 5.2:
jdbc:sybase:Tds:hostname:port/dbname?charset=eucgb&jconnect_version=0