abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 21:11 | Nová verze

    Byl vydán Debian 13 s kódovým názvem Trixie. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 1
    včera 15:55 | Zajímavý software

    WLED je open-source firmware pro ESP8266/ESP32, který umožňuje Wi-Fi ovládání adresovatelných LED pásků se stovkami efektů, synchronizací, audioreaktivním módem a Home-Assistant integrací. Je založen na Arduino frameworku.

    Indiánský lotr | Komentářů: 0
    8.8. 15:33 | Nová verze

    Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána v nové verzi 2025.8.

    Ladislav Hagara | Komentářů: 3
    8.8. 14:22 | IT novinky

    Herní studio Hangar 13 vydalo novou Mafii. Mafia: Domovina je zasazena do krutého sicilského podsvětí na začátku 20. století. Na ProtonDB je zatím bez záznamu.

    Ladislav Hagara | Komentářů: 1
    8.8. 13:22 | IT novinky

    Operátor O2 má opět problémy. Jako omluvu za pondělní zhoršenou dostupnost služeb dal všem zákazníkům poukaz v hodnotě 300 Kč na nákup telefonu nebo příslušenství.

    Ladislav Hagara | Komentářů: 8
    8.8. 05:55 | IT novinky

    Společnost OpenAI představila GPT-5 (YouTube).

    Ladislav Hagara | Komentářů: 2
    8.8. 05:00 | Nová verze

    Byla vydána (𝕏) červencová aktualizace aneb nová verze 1.103 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.103 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    7.8. 17:33 | IT novinky

    Americký prezident Donald Trump vyzval nového generálního ředitele firmy na výrobu čipů Intel, aby odstoupil. Prezident to zdůvodnil vazbami nového šéfa Lip-Bu Tana na čínské firmy.

    Ladislav Hagara | Komentářů: 10
    7.8. 16:55 | Nová verze

    Bylo vydáno Ubuntu 24.04.3 LTS, tj. třetí opravné vydání Ubuntu 24.04 LTS s kódovým názvem Noble Numbat. Přehled novinek a oprav na Discourse.

    Ladislav Hagara | Komentářů: 0
    7.8. 16:44 | Nová verze

    Byla vydána verze 1.89.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (46%)
     (20%)
     (4%)
     (5%)
     (3%)
     (1%)
     (1%)
     (19%)
    Celkem 318 hlasů
     Komentářů: 23, poslední 4.8. 13:01
    Rozcestník

    Dotaz: Problém s htmlspecialchars();

    14.3.2012 02:38 Dědek
    Problém s htmlspecialchars();
    Přečteno: 680×
    Ahoj, proč mi tohle pořád hází chybu a nic se nevypíše?
    kód
    echo htmlspecialchars($row['title'], ENT_XHTML, 'UTF-8');
    chyba
    Notice: Use of undefined constant ENT_XHTML - assumed 'ENT_XHTML' in ...
    Warning: htmlspecialchars() expects parameter 2 to be long, string given in ...
    porovnání v mysql sloupce title je utf8_unicode_ci, soubor je v kódování v UTF-8, html na výstupu je taky v UTF-8. Poradí někdo?

    Řešení dotazu:


    Odpovědi

    14.3.2012 06:33 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    Podle dokumentace byla konstanta ENT_XHTML přidána až v PHP 5.4.0 (viz sekce Changelog na stránce s popisem). Pokud používáte starší verzi, není tato varianta k dispozici.
    14.3.2012 13:25 Dědek
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    Tak problém byl tady, v připojení k mysql jsem nastavil kódování utf-8 které ovšem nebere v potaz, nechápu k čemu tam tedy je

    $pdo = new PDO ('mysql:host='.MYSQL_HOST.';dbname='.MYSQL_DB.';charset=UTF-8', MYSQL_USER, MYSQL_PASSWORD);


    Jelikož jsem nesehnal nic jiného, vyzkoušel jsem tohle co jsem používal kdysi a vše bylo OK

    $pdo->query("SET NAMES `UTF8`");


    Tak jak to tedy je, poradí někdo? Děkuji
    14.3.2012 13:52 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    Pletete dvě naprosto rozdílné věci dohromady, náprava uváděné chyby byla vysvělena v prvním příspěvku.
    Obvykle stačí jen htmlspecialchars($row['title']);, nebo použít PHP konstanty, které ve vaší verzi existuji.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    14.3.2012 14:42 Dědek
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    htmlspecialchars($row['title']); určitě nestačí, píše to paznaky u čekých znaků...
    14.3.2012 15:15 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    Nad daty UTF-8 tato funkce bude fungovat správně jak s kódováním ISO-8859-1 (default do verze 5.4.0), tak s kódováním UTF-8.
    Následný kód by měl dát 3 stejné řádky: '&lt;ěščřžýáíéďťňúůĚŠČŘŽÝÁÍÉĎŤŇÚŮ&gt;&quot;<br />
    <?php
    $text='\'<ěščřžýáíéďťňúůĚŠČŘŽÝÁÍÉĎŤŇÚŮ>"';
    echo htmlspecialchars($text)."<br />\n";
    echo htmlspecialchars($text,ENT_COMPAT,'ISO-8859-1')."<br />\n";
    echo htmlspecialchars($text,ENT_COMPAT,'UTF-8')."<br />\n";
    
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    14.3.2012 16:07 Dědek
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    Teď se ale dívám, že všechno co táhám z mysql nemá české znaky, jak tedy nastavit utf-8 pro PDO? Díky
    14.3.2012 16:14 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    A důležitá otázka: „Máte to v DB v utf-8?“
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    15.3.2012 12:54 Dědek
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    Ano jsou, nastavené kódován pro sloupečky mám utf8_unicode_ci je to dobře?
    14.3.2012 16:17 Kit
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    Správně jsi použil
    $pdo->query("SET NAMES `UTF8`");
    ale je nutné to udělat ještě před ukládáním dat. V tuto chvíli jsou zřejmě data v DB špatně.
    14.3.2012 16:32 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    A taky buď databáze nebo/a tabulka nebo/a sloupec by měl být nastaven na UTF-8.
    $pdo->query("SET NAMES `UTF8`");
    nebo:
    $pdo->query("SET NAMES 'UTF8'");
    já bych použil to druhé…
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    14.3.2012 16:49 Kit
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    Tak ty obrácené apostrofy jsem při kopírování nějak přehlédl. MySQL moc nepoužívám, stane se. V některých případech se to dá i zjednodušit:
    $pdo->query("SET NAMES UTF8;");
    14.3.2012 16:53 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    Evidentně to žere všechno…
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    15.3.2012 13:00 Dědek
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    A proč to druhé?
    15.3.2012 13:17 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    Protože ` a ' mají jiný význam, ale evidentně zde je to zaměnitelné a je to úhlu pohledu co vlastně utf8 znamená (jaký je druh entity).
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    15.3.2012 12:58 Dědek
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    A co použít tohle? $pdo = new PDO ('mysql:host='.$host.';dbname='.$db.';charset=UTF-8', $user, $password)); nebo $pdo = new PDO ('mysql:host='.$host.';dbname='.$db.';charset=UTF-8', $user, $password, array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES UTF8"));

    Díky
    15.3.2012 12:58 Dědek
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    A co použít tohle?
    $pdo = new PDO ('mysql:host='.$host.';dbname='.$db.';charset=UTF-8', $user, $password));
    nebo
    $pdo = new PDO ('mysql:host='.$host.';dbname='.$db.';charset=UTF-8', $user, $password, array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES UTF8"));
    Díky
    16.3.2012 13:18 Dědek
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    Nikdo nic?
    16.3.2012 13:58 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    A co?
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    16.3.2012 23:26 Dědek
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    No co kdo říká na to nastavení UTF-8 v těch dvou příkladech co jsem psal...
    18.3.2012 14:02 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    Nikoho asi nebaví se opakovat, či hledat N-tou variaci na stejné téma :-(.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    18.3.2012 14:33 Kit
    Rozbalit Rozbalit vše Re: Problém s htmlspecialchars();
    Zřejmě s tím i ostatní souhlasí. Osobně bych bych přidal ještě atribut PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, ale to ses určitě dočetl v jiném vláknu.

    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.