【发布时间】:2011-04-27 03:12:39
【问题描述】:
现在我正在和我的朋友一起工作,他是越南人,他想使用越南语创建一个网站,但我们遇到了编码 UTF-8 的问题。 我写了一个Filter类如下:
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 CharsetFilter implements Filter
{
private String encoding;
public void init(FilterConfig config) throws ServletException
{
encoding = config.getInitParameter("requestEncoding");
if( encoding==null ) encoding="UTF-8";
}
public void doFilter(ServletRequest request, ServletResponse response, FilterChain next) throws IOException, ServletException
{
// Respect the client-specified character encoding
// (see HTTP specification section 3.4.1)
if(null == request.getCharacterEncoding())
request.setCharacterEncoding(encoding);
/** * Set the default response content type and encoding */
response.setContentType("text/html; charset=UTF-8");
response.setCharacterEncoding("UTF-8");
next.doFilter(request, response);
}
@Override
public void destroy() {}
}
web.xml 中的配置:
<filter>
<filter-name>CharsetFilter</filter-name>
<filter-class>com.mypackage.CharsetFilter</filter-class>
<init-param>
<param-name>requestEncoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>CharsetFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
在服务器资源 - sun-resources.xml:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE resources PUBLIC "-//Sun Microsystems, Inc.//DTD Application Server 9.0 Resource Definitions //EN" "http://www.sun.com/software/appserver/dtds/sun-resources_1_3.dtd">
<resources>
<jdbc-connection-pool allow-non-component-callers="false" associate-with-thread="false" connection-creation-retry-attempts="0" connection-creation-retry-interval-in-seconds="10" connection-leak-reclaim="false" connection-leak-timeout-in-seconds="0" connection-validation-method="auto-commit" datasource-classname="com.mysql.jdbc.jdbc2.optional.MysqlDataSource" fail-all-connections="false" idle-timeout-in-seconds="300" is-connection-validation-required="false" is-isolation-level-guaranteed="true" lazy-connection-association="false" lazy-connection-enlistment="false" match-connections="false" max-connection-usage-count="0" max-pool-size="32" max-wait-time-in-millis="60000" name="vietweb" non-transactional-connections="false" pool-resize-quantity="2" res-type="javax.sql.DataSource" statement-timeout-in-seconds="-1" steady-pool-size="8" validate-atmost-once-period-in-seconds="0" wrap-jdbc-objects="false">
<property name="serverName" value="localhost"/>
<property name="portNumber" value="3306"/>
<property name="databaseName" value="vietweb"/>
<property name="User" value="root"/>
<property name="Password" value="12345"/>
<property name="useUnicode" value="true"/>
<property name="characterEncoding" value="UTF8"/>
<property name="URL" value="jdbc:mysql://localhost:3306/vietweb"/>
<property name="driverClass" value="com.mysql.jdbc.Driver"/>
</jdbc-connection-pool>
<jdbc-resource enabled="true" jndi-name="jdbc/vietweb" object-type="user" pool-name="mysql_vietweb_rootPool"/>
</resources>
在 JSF 页面中:
<meta http-equiv="content-type" content="text/html; charset=utf-8"/>
但它没有被编码为越南语。 我们怎样才能让它编码成越南语?
将数据保存到数据库的问题(我使用的数据库是 MySQL) 我想要/期待这个输出:
chuyển phát nhanh để chuyển tới những cuốn sách
但我看到了这个意外的输出:
chuy?n phát nhanh ?? chuy?n t?i nh?ng ??u sách
【问题讨论】:
-
数据是否来自数据库?
-
到底哪里出错了?在 JSF 页面中显示数据库数据或将 JSF 表单参数保存在数据库中?意外的结果究竟如何?更新您的问题以包含预期结果和意外结果的副本(只需一个单词或简单的句子就足够了)。
-
嗨 Odelya 和 BalusC 我正在编辑我的问题,它来自将数据保存到数据库中并显示?字符
标签: mysql jsf unicode character-encoding