abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 18:00 | IT novinky

    DuckDuckGo AI Chat umožňuje "pokecat si" s GPT-3.5 Turbo od OpenAI nebo Claude 1.2 Instant od Anthropic. Bez vytváření účtu. Všechny chaty jsou soukromé. DuckDuckGo je neukládá ani nepoužívá k trénování modelů umělé inteligence.

    Ladislav Hagara | Komentářů: 0
    dnes 14:22 | IT novinky

    VASA-1, výzkumný projekt Microsoftu. Na vstupu stačí jediná fotka a zvukový záznam. Na výstupu je dokonalá mluvící nebo zpívající hlava. Prý si technologii nechá jenom pro sebe. Žádné demo, API nebo placená služba. Zatím.

    Ladislav Hagara | Komentářů: 2
    dnes 04:44 | Nová verze

    Nová čísla časopisů od nakladatelství Raspberry Pi: MagPi 140 (pdf) a HackSpace 77 (pdf).

    Ladislav Hagara | Komentářů: 0
    dnes 01:00 | Nová verze

    ESPHome, tj. open source systém umožňující nastavovat zařízení s čipy ESP (i dalšími) pomocí konfiguračních souborů a připojit je do domácí automatizace, například do Home Assistantu, byl vydán ve verzi 2024.4.0.

    Ladislav Hagara | Komentářů: 0
    včera 22:11 | IT novinky Ladislav Hagara | Komentářů: 0
    včera 20:55 | Nová verze

    Neziskové průmyslové konsorcium Khronos Group vydalo verzi 1.1 specifikace OpenXR (Wikipedie), tj. standardu specifikujícího přístup k platformám a zařízením pro XR, tj. platformám a zařízením pro AR (rozšířenou realitu) a VR (virtuální realitu). Do základu se z rozšíření dostalo XR_EXT_local_floor. Společnost Collabora implementuje novou verzi specifikace do platformy Monado, tj. open source implementace OpenXR.

    Ladislav Hagara | Komentářů: 2
    včera 17:22 | Nová verze

    Byla vydána nová verze 0.38.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 4.4 nebo novější a také libplacebo 6.338.2 nebo novější.

    Ladislav Hagara | Komentářů: 13
    včera 17:11 | Nová verze

    ClamAV (Wikipedie), tj. multiplatformní antivirový engine s otevřeným zdrojovým kódem pro detekci trojských koní, virů, malwaru a dalších škodlivých hrozeb, byl vydán ve verzích 1.3.1, 1.2.3 a 1.0.6. Ve verzi 1.3.1 je mimo jiné řešena bezpečnostní chyba CVE-2024-20380.

    Ladislav Hagara | Komentářů: 2
    včera 12:11 | IT novinky

    Digitální a informační agentura (DIA) oznámila (PDF, X a Facebook), že mobilní aplikace Portál občana je ode dneška oficiálně venku.

    Ladislav Hagara | Komentářů: 10
    včera 05:11 | Komunita

    #HACKUJBRNO 2024, byly zveřejněny výsledky a výstupy hackathonu města Brna nad otevřenými městskými daty, který se konal 13. a 14. dubna 2024.

    Ladislav Hagara | Komentářů: 2
    KDE Plasma 6
     (68%)
     (10%)
     (2%)
     (20%)
    Celkem 564 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    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: 392×
    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:


    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
    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
    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
    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   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.