解決JSP頁面中文亂碼插入到資料庫的問題

來源:互聯網
上載者:User

標籤:

在JSP頁面使用表單註冊一個使用者名稱的時候,查看到資料庫裡面的表中文顯示亂碼的情況有兩種:

  1、JSP頁面傳進來的參數中文就是亂碼,則是前台的問題,這個時候寫一個過濾器就好了,可以寫如下的一個過濾器

  

public class EncodingFilter implements Filter {
String encoding;
private static final String DEFAULT_CHARACTER_ENCODING = "UTF-8";
public EncodingFilter() {
}

public void destroy() {
}

public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
// TODO Auto-generated method stub
// place your code here

// pass the request along the filter chain
try {
if ((encoding!=null)&&(encoding.length()>0)) {
request.setCharacterEncoding(encoding);
//驗證是否進入這個if語句
System.out.println("in filter and encoding :"+encoding);
}else {
request.setCharacterEncoding(DEFAULT_CHARACTER_ENCODING);
}
} catch (UnsupportedEncodingException e) {
request.setCharacterEncoding(DEFAULT_CHARACTER_ENCODING);
e.printStackTrace();
}
chain.doFilter(request, response);
}

public void init(FilterConfig fConfig) throws ServletException {
//擷取設定檔中的encoding
encoding = fConfig.getInitParameter("encoding");
//確認web容器初始化的時候這個filter也已經初始化了
System.out.println(encoding);
}

}

注意這有一個關鍵的地方,你使用過濾器的話,表單的提交方式必須是post,如果還是get方式,則還是亂碼的

或者有個笨辦法

1. 在b.jsp中把String name=request.getParameter("name");修改為
String name=new String(request.getParameter("name").getBytes("ISO-8859-1"),"GB2312");
2. 這時再在頁面上顯示,則就是中文了。

這樣也可以的

 

  2、第二種造成的方法就是資料庫裡面的字元集的問題,這個的問題不是比較專業的從事資料庫的朋友,一般不太理解其中的原理,目前我只能參考別人的辦法

具體就是伺服器的字元集和用戶端的字元集不一致,解決辦法也可以百度一下,網上就有。

 

解決JSP頁面中文亂碼插入到資料庫的問題

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.