Portál AbcLinuxu, 26. dubna 2024 15:13


Dotaz: JSF 1.2, Facelets 1.1.15, h:form, MySQL a UTF-8

20.4.2010 09:38 fastcoretux | skóre: 5 | Brno
JSF 1.2, Facelets 1.1.15, h:form, MySQL a UTF-8
Přečteno: 393×
Odpovědět | Admin
Zdravíčko, opět zase trošku bojuji s JSF :-). V hlavičce stránek je samozřejmě nastaveno <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />. Soubory jsou taktéž kódovány v UTF-8 a v MySQL databázi se používá porovnáni utf8_general_ci. Když se vypisují data z databáze, která jsemm vložil prostřednictvím phpmyadmin či klasického terminálového klienta tak je vše v pořádku.

Problém nastává když vkládám české znaky do databáze prostřednictvím formuláře <h:form acceptcharset="UTF-8">.

Vy-googlil jsem řešení pomocí implemenatce následujícího jedoduchého filteru ale to bohužel také nepomohlo.
public class UTF8Filter implements Filter {
	public void init(FilterConfig config) throws ServletException {
       
    }

    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) 
                                                           throws IOException, ServletException {
        request.setCharacterEncoding("UTF-8");
        response.setCharacterEncoding("UTF-8");
        response.setContentType("text/html");
        
        chain.doFilter(request, response);
    }

    public void destroy() {
       
    }

 

}
Co tedy s tím? Že by JSF mělo problém s UTF-8 ... to se mi nezdá. Je dost možné že je to klasická chyba mezi židlí a klávesnicí ale opravdu už si nevím rady a čekám na ty vaše :-)

Řešení dotazu:


Nástroje: Začni sledovat (1) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

20.4.2010 10:36 Filip Jirsák | skóre: 68 | blog: Fa & Bi
Rozbalit Rozbalit vše Re: JSF 1.2, Facelets 1.1.15, h:form, MySQL a UTF-8
Odpovědět | | Sbalit | Link | Blokovat | Admin
Problém je v tom, že HTTP specifikace nijak neurčuje kódování znaků v datech formuláře posílaných na server a neurčuje ani způsob, jak to kódování serveru sdělit. Prohlížeče tedy postupují tak, že data posílají ve stejném kódování, v jakém je daná stránka s formulářem.

To ale server neví, takže mu to musíte sdělit právě voláním request.setCharacterEncoding(), a to ještě před tím, než se z požadavku začne číst obsah nebo parametry – ideálně tedy v prvním filtru, který se zavolá. Kdysi jsem o tom napsal blog: Servlety a kódování znaků.

U vás bude problém pravděpodobně v tom, že se filtr buď nevolá vůbec, nebo se dostane k práci příliš pozdě – v okamžiku, kdy už se někdo pokoušel přečíst parametry, a změna kódování již není možná.
20.4.2010 13:04 Martin Beránek | skóre: 33 | blog: mousehouse | Brno
Rozbalit Rozbalit vše Re: JSF 1.2, Facelets 1.1.15, h:form, MySQL a UTF-8
Odpovědět | | Sbalit | Link | Blokovat | Admin
Souhlasím s panem Jirsákem, ten filtr funguje, jenom se vám zřejmě nevolá, nebo se volá až po přečtení parametrů. Doporučuji volat jako první filtr namapovaný na FacesServlet.
never use rm after eight
20.4.2010 14:43 fastcoretux | skóre: 5 | Brno
Rozbalit Rozbalit vše Re: JSF 1.2, Facelets 1.1.15, h:form, MySQL a UTF-8
Odpovědět | | Sbalit | Link | Blokovat | Admin
Příloha:
Děkuji za rychlé a užitečné odpovědi. Věřím, že tudy cesta určitě povede. Co se týká JSF tak jsem na samém začátku, takže podle toho co jsem si našel se filtr nastavuje v souboru web.xml, který zasílám v příloze. Nejsem si úplně jistý jestli ho mapuji správně... Tak bych vás chtěl požádat, jestli by jste na něj mohli zběžně kouknout.

Ještě pro jistotu jistotu uvedu, že používám GlassFish Server Open Source Edition 3.0.

Díky moc :-)
20.4.2010 15:54 Filip Jirsák | skóre: 68 | blog: Fa & Bi
Rozbalit Rozbalit vše Re: JSF 1.2, Facelets 1.1.15, h:form, MySQL a UTF-8
<filter-mapping>
  <filter-name>Set Character Encoding</filter-name>
  <servlet-name>Faces Servlet</servlet-name>
  <url-pattern>/faces/*</url-pattern>
</filter-mapping>
Smažte ten řádek s url-pattern, ten je tam navíc. Myslím, že kombinované nastavení filtru na pojmenovaný servlet a na URL v jednom bloku nefunguje. Vám navíc stačí filtr zaregistrovat k tomu servletu.
20.4.2010 16:14 fastcoretux | skóre: 5 | Brno
Rozbalit Rozbalit vše Re: JSF 1.2, Facelets 1.1.15, h:form, MySQL a UTF-8
Tento řádek mi tam omylem zůstal. Už je odstraněn ale stále problém přetrvává...
20.4.2010 16:28 Filip Jirsák | skóre: 68 | blog: Fa & Bi
Rozbalit Rozbalit vše Re: JSF 1.2, Facelets 1.1.15, h:form, MySQL a UTF-8
Zkuste si nějakým výpisem do logu otestovat, zda se filtr provádí, jaké je nastavené kódování požadavku a jaký je text získaný z formuláře – abyste zjistil, ve kterém místě je přesně chyba.
Řešení 1× (fastcoretux (tazatel))
27.4.2010 10:18 fastcoretux | skóre: 5 | Brno
Rozbalit Rozbalit vše Re: JSF 1.2, Facelets 1.1.15, h:form, MySQL a UTF-8
Po odlazení pomocí výpisu do logu jsem zjistil, že problém byl úplně na jiném místě a to konkrétně v parametru pro Mysql JDBC connector. Stačilo tedy v souboru persistence.xml upravit řádek
<property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/mydb" />
následujícím způsobem.
<property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/mydb?characterEncoding=utf8" />
Po této úpravě nebylo třeba filtr vůbec používat...

Každopádně děkuju moc za všechny cenné rady ;-)

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.