フォームから入力した国際文字が入力したとおりに保存されず、保存されたデータがデータベースに保存されたとおりに返されません。
「çanak çömlek patladı」と入力してフォームの保存をクリックすると、ページに「çanak çömlek patladı」と表示されますが、データベースには「çanak çömlek patlad?」が保存されていますか? もう一度ページにアクセスすると、「anak �mlek patlad?」と表示されます。何も変更せずにフォームの保存をクリックすると、データベースには「?anak ??mlek patlad?」と保存されます。ブラウザに「?anak ??mlek patlad?」と表示されます。
次の構成のMySQLサーバーがあります。
default-collation=utf8
collation_server=utf8_unicode_ci
character_set_server=utf8
default-character-set=utf8
データベースの文字セットは utf8 で、データベースの照合順序は utf8_unicode_ci で、使用しているテーブルも同じように設定されています。
JSP ファイルの最初の行は次のとおりです。
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" %>
HTMLヘッダーは次のとおりです。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Test</title>
</head>
私はコンパイルされた EncodingFilter クラスを持っています:
import java.io.IOException;
import javax.servlet.*;
public class EncodingFilter
implements Filter
{
public EncodingFilter()
{
}
public void init(FilterConfig filterconfig)
throws ServletException
{
filterConfig = filterconfig;
encoding = filterConfig.getInitParameter("encoding");
}
public void doFilter(ServletRequest servletrequest, ServletResponse servletresponse, FilterChain filterchain)
throws IOException, ServletException
{
servletrequest.setCharacterEncoding(encoding);
filterchain.doFilter(servletrequest, servletresponse);
}
public void destroy()
{
}
private String encoding;
private FilterConfig filterConfig;
}
このクラスは、web.xml ファイルで次のように参照されます。
<filter>
<filter-name>EncodingFilter</filter-name>
<filter-class>EncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>EncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
システムを再起動したため、Tomcat と MySQL サーバーを再起動し、ログを確認しましたが、上記の構成のいずれにもエラーはありません。
誰か助けてくれませんか?