Portál AbcLinuxu, 6. května 2024 15:13


Dotaz: Problém s htmlspecialchars();

14.3.2012 02:38 Dědek
Problém s htmlspecialchars();
Přečteno: 663×
Odpovědět | Admin
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:


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

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();
Odpovědět | | Sbalit | Link | Blokovat | Admin
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();
Odpovědět | | Sbalit | Link | Blokovat | Admin
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();
Odpovědět | | Sbalit | Link | Blokovat | Admin
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, (c) 1999-2007 Stickfish s.r.o.