近來在調試Jsp文件問題時,中文亂碼現象常常遇到,現將處理方法總結一下,供你們參考:
1.Jsp文件頁面顯示亂碼,這種狀況比較好處理,在頁面的Page指令加上以下一項就OK了:
<%@ page contentType="text/html; charset=gb2312"%>
2.Jsp頁面採用表單提交時,提交的數據中含有中文,這時咱們獲取表單數據後,展現到其它頁面時也會出現亂碼,解決方案是在提交處理的Servlet裏接收數據時,先加上以下一行代碼:
request.setCharacterEncoding("gb2312");
這是其中的一種做法,當頁面較少時還好,若是頁面較多,我每添加新的頁面就要加上這句話,因此能夠採用過濾器來解決,具體解決步驟以下:
首先寫一個過濾器類,代碼以下:
package demo;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
public class SetCharacterEncodingFilter implements Filter {
public void destroy() {
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain)throws IOException, ServletException {
request.setCharacterEncoding("gbk");
// 傳遞控制到下一個過濾器
chain.doFilter(request, response);
}
public void init(FilterConfig filterConfig) throws ServletException {
}
}
而後在web.xml文件中添加以下代碼:
<filter>
<!--爲過濾器起個名字-->
<filter-name>Set Character Encoding</filter-name>
<!--過濾器類的包名.類名-->
<filter-class>demo.SetCharacterEncodingFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>Set Character Encoding</filter-name>
<!--匹配全部的請求-->
<url-pattern>/*</url-pattern>
</filter-mapping>
這樣全部的請求都將交由這個過濾器處理下,這樣不管咱們添加多少個頁面均可以放心了,不用總考慮要加那麼一句代碼了.
3.在存取數據庫時發生亂碼現象,這種現象比較鬱悶,處理起來相對複雜一點.
首先要在數據存入數據庫時,進行以下編碼的轉換:如咱們要把含有中文的字符串存入數據庫,首先:
String s=request.getParameter("author");
String author=new String(s.getBytes("ISO8859_1"),"gb2312");
在從數據庫取出展現到頁面時,也要通過以下轉換:
String s=rs.getString("author");
String author=new String(s.getBytes("GB2312"),"ISO8859_1");
以上是我總結的對三種Jsp文件中文亂碼的處理方法,但願對你們有所幫助.