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í
×
    dnes 16:22 | IT novinky

    Internetový prohlížeč Ladybird ohlásil tranzici z programovacího jazyka C++ do Rustu. Přechod bude probíhat postupně a nové komponenty budou dočasně koexistovat se stávajícím C++ kódem. Pro urychlení práce bude použita umělá inteligence, při portování první komponenty prohlížeče, JavaScriptového enginu LibJS, bylo během dvou týdnů pomocí nástrojů Claude Code a Codex vygenerováno kolem 25 000 řádků kódu. Nejedná se o čistě autonomní vývoj pomocí agentů.

    NUKE GAZA! 🎆 | Komentářů: 2
    dnes 15:55 | Nová verze

    Byl vydán Mozilla Firefox 148.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Nově lze snadno povolit nebo zakázat jednotlivé AI funkce. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 148 bude brzy k dispozici také na Flathubu a Snapcraftu.

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

    Byla vydána nová verze 22.1.0, tj. první stabilní verze z nové řady 22.1.x, překladačové infrastruktury LLVM (Wikipedie). Přehled novinek v poznámkách k vydání: LLVM, Clang, LLD, Extra Clang Tools a Libc++.

    Ladislav Hagara | Komentářů: 0
    dnes 12:22 | Humor

    X86CSS je experimentální webový emulátor instrukční sady x86 napsaný výhradně v CSS, tedy bez JavaScriptu nebo dalších dynamických prvků. Stránka 'spouští' assemblerovový program mikroprocesoru 8086 a názorně tak demonstruje, že i prosté CSS může fungovat jako Turingovsky kompletní jazyk. Zdrojový kód projektu je na GitHubu.

    NUKE GAZA! 🎆 | Komentářů: 3
    dnes 12:11 | Nová verze

    Po šesti letech byla vydána nová verze 1.3 webového rozhraní ke gitovým repozitářům CGit.

    Ladislav Hagara | Komentářů: 0
    dnes 02:33 | Nová verze

    Byla vydána nová verze 6.1 linuxové distribuce Lakka (Wikipedie), jež umožňuje transformovat podporované počítače v herní konzole. Nejnovější Lakka přichází s RetroArchem 1.22.2.

    Ladislav Hagara | Komentářů: 0
    dnes 02:11 | Nová verze

    Matematický software GNU Octave byl vydán ve verzi 11.1.0. Podrobnosti v poznámkách k vydání. Vedle menších změn rozhraní jsou jako obvykle zahrnuta také výkonnostní vylepšení a zlepšení kompatibility s Matlabem.

    |🇵🇸 | Komentářů: 1
    včera 21:44 | Nová verze

    Weston, referenční implementace kompozitoru pro Wayland, byl vydán ve verzi 15.0.0. Přehled novinek v příspěvku na blogu společnosti Collabora. Vypíchnout lze Lua shell umožňující psát správu oken v jazyce Lua.

    Ladislav Hagara | Komentářů: 0
    včera 21:11 | Nová verze

    Organizace Apache Software Foundation (ASF) vydala verzi 29 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.

    Ladislav Hagara | Komentářů: 3
    včera 18:22 | IT novinky

    Ústavní soud na svých webových stránkách i v databázi NALUS (NÁLezy a USnesení Ústavního soudu) představil novou verzi chatbota využívajícího umělou inteligenci. Jeho posláním je usnadnit veřejnosti orientaci v rozsáhlé judikatuře Ústavního soudu a pomoci jí s vyhledáváním informací i na webových stránkách soudu, a to i v jiných jazycích. Jde o první nasazení umělé inteligence v rámci webových stránek a databází judikatury českých soudů.

    Ladislav Hagara | Komentářů: 17
    Které desktopové prostředí na Linuxu používáte?
     (18%)
     (6%)
     (0%)
     (11%)
     (27%)
     (2%)
     (5%)
     (1%)
     (12%)
     (26%)
    Celkem 953 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: mariadb (mysql) : invalid utf8 character string

    25.6.2020 08:27 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    mariadb (mysql) : invalid utf8 character string
    Přečteno: 1647×
    Zdravím,

    Mám sql příkaz, který uchovává v databázi obrázek a náhled. Po přechodu na novější verzi databáze dostávám warnings po vykonání příkazu k uložení - Invalid utf8 character string blabla.

    Pole k uložení dat NEMAJÍ určený typ ( ostatní pole a tabulka utf8-czech-ci ). Nevím co změnit, aby hláška zmizela ( a přes mega soubor s hláškou ).

    Vyšší utf asi nepomůže, protože to nejsou znaky. co ukládám, ale směsice - no prostě obrázek. Doposud používám fci mysqli::real-ecsape-string, ale ta nedokáže hlášce zabránit.

    Díky za každou dobrou radu.

    Řešení dotazu:


    Odpovědi

    25.6.2020 08:44 EtDirloth | skóre: 11
    Rozbalit Rozbalit vše Re: mariadb (mysql) : invalid utf8 character string
    Bolo by fajn spomenut verziu DB a ukazat strukturu tabulky + prikazu.

    Bez tychto detailov mi napada, ze to ide do nejakeho varcharu (ktory implikuje ten charset), a teda treba pouzit typ stlpca priamo urceny pre binarne data. Napriklad blob a jeho varianty, resp. varbinary.
    25.6.2020 09:31 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: mariadb (mysql) : invalid utf8 character string
    Ahoj.

    Verze serveru: 5.7.30-0ubuntu0.18.04.1 - (Ubuntu)

    struktura tabukky
     	# 	Název 	Typ 	Porovnávání 	Vlastnosti 	Nulový 	Výchozí 	Komentáře 	Další 	Operace
    	1 	IDPrimární 	varchar(64) 	utf8_czech_ci 		Ne 	Žádná 			
    	2 	Data 	mediumblob 			Ano 	NULL 			
    	3 	Thumb 	mediumblob 			Ne 	Žádná 			
    	4 	Note 	varchar(200) 	utf8_czech_ci 		Ne 	Žádná 			
    	5 	Mime 	varchar(30) 	utf8_czech_ci 		Ne 	Žádná 			
    	6 	ThumbMime 	varchar(30) 	utf8_czech_ci 		Ne 	Žádná 			
    	7 	Name 	varchar(128) 	utf8_czech_ci 		Ne 	Žádná 			
    Data a Thumb jsou blob, bez určení typu porovnávání.

    sqlko ti moc nenapoví, to jsem udělal v zápisu chyby. K serveru se dostane :
    Zpráva MySQL : Warning : ( 1300 ) Invalid utf8 character string: 'FFD8FF'
    INSERT INTO Images SET ID='0058a74348546954cde69c66a293d283', Note='', Mime='image/jpeg; charset=binary', ThumbMime='image/jpeg; charset=binary', Name='csc_2020_12_ZS+PL_str02.jpg', Data='����\0?JFIF......tam někde je ta chyba
    na Data i Thubs použiju před ulokládaním real_escape_string

    Ještě upozornění : obrázek ani náhled nevypadají poškozeně, zobrazí se bez hlášek ...
    25.6.2020 09:32 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: mariadb (mysql) : invalid utf8 character string
    Možná potom real_escape_string je tím problémem.
    25.6.2020 09:38 EtDirloth | skóre: 11
    Rozbalit Rozbalit vše Re: mariadb (mysql) : invalid utf8 character string
    Ano, vyzera to tak - mysql_real_escape_string neescapuje multibyte znaky => interpretuje literal v kontexte charsetu pripojenia; preto na rozdiel od mysql_escape_string ma aj druhy parameter. Vyskusaj teda mysql_escape_string.
    25.6.2020 09:41 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: mariadb (mysql) : invalid utf8 character string
    To už jsem zkoušel, výsledek je stejný .. zapomněl jsem napsat.
    25.6.2020 09:48 EtDirloth | skóre: 11
    Rozbalit Rozbalit vše Re: mariadb (mysql) : invalid utf8 character string
    Potom mozno explicitne nastavit set_charset pri pouziti mysqli_real_escape_string?
    Řešení 1× (Milan Uhrák (tazatel))
    25.6.2020 11:54 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: mariadb (mysql) : invalid utf8 character string
    Píšu, že charset nic nemění. Nakonec jsem přes jiné otázky googlu našel funkci load_file, která zohlednuje blob pole, a nereflektuje charset ... trochu drbání levou rukou za pravým uchem, no, ale budiž.

    Uhrák
    Řešení 1× (Filip Jirsák)
    25.6.2020 13:40 OldFrog {Ondra Nemecek} | skóre: 36 | blog: Žabákův notes | Praha
    Rozbalit Rozbalit vše Re: mariadb (mysql) : invalid utf8 character string
    Binární data nemůžete vkládat jen tak v insertu, musíte je buď převést do bezpečné podoby base64 nebo hex anebo je vložit tou funkcí load_file. Koukněte na příklady do dokumentace k příslušné databázi. Taky koukněte, jak jsou ty bloby reprezentované při dumpu databáze.
    -- OldFrog
    20.7.2020 06:37 PetrHL | skóre: 17 | blog: petr_h | Neratovice
    Rozbalit Rozbalit vše Re: mariadb (mysql) : invalid utf8 character string
    Nepoužívejte utf8. Je to alias pro utf8mb3 a to nechcete. Vždy používejte utf8mb4.
    "Do, or do not. There is no 'try.'" -- Jedi Master Yoda | CQRLOG | CQRPROP | HamQTH | Domů

    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.