程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> JSP編程 >> 關於JSP >> Jsp/Servlet接收FORM表格參數時輸出亂碼的處理

Jsp/Servlet接收FORM表格參數時輸出亂碼的處理

編輯:關於JSP

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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved