• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

PHP, łączenie się za pomocą PDO - brak polskich znaków, json_decode();

Object Storage Arubacloud
0 głosów
826 wizyt
pytanie zadane 14 maja 2018 w PHP przez CzarnYU_owca Nowicjusz (150 p.)
edycja 21 maja 2018 przez CzarnYU_owca

W dokumencie ustawione kodowanie UTF-8, meta również:

<head>
	 <meta charset="utf-8">
</head>
$db = new PDO("mysql:host={$conn['host']};dbname={$conn['database']};charset=utf8", $conn['user'], $conn['password'], [PDO::ATTR_EMULATE_PREPARES => false, PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION]);

Pomimo tego zwraca

{"id":26,"0":26,"typ":"kartk\u00f3wka","1":"kartk\u00f3wka","nastawienie":"negatywne","2":"negatywne","przedmiot":"bia\u0142oruski","3":"bia\u0142oruski","data":"2018-05-16","4":"2018-05-16","lekcja":5,"5":5}

Może ktoś zna rozwiązanie ;)
Z góry dziękuję

EDIT: Zapomniałem dodać, że w bazie danych znaki polskie są.

1 odpowiedź

0 głosów
odpowiedź 14 maja 2018 przez Chess Szeryf (76,710 p.)
wybrane 16 maja 2018 przez CzarnYU_owca
 
Najlepsza

Zmień może kodowanie na utf8 dla całej bazy danych MySQL.

https://dev.mysql.com/doc/refman/8.0/en/server-options.html#option_mysqld_character-set-server

Możliwe, że masz zaindeksowane stare dane i nie wczytują Ci się zmiany, wtedy naciśnij ctrl+F5 lub ctrl+R bądź wyczyść pamięć podręczną, cache, itp..

Do zobaczenia pełnego wykazu ustawień konfiguracyjnych użyj polecenia (u Ciebie te pliki też są chyba w bin, więc musisz wydać polecenie z katalogu bin lub odwołać się do tego katalogu):

c:\xampp\mysql\bin>mysqld --verbose --help

Znajdź tam między innymi takie wpisy jak:

character-set-client-handshake                       
character-set-filesystem                                
character-set-server
collation-server

Z tych co wymieniłem, to musisz zmienić tylko dwa chyba. character-set-server i collation-server.

Jeśli pisze jakieś latin1, czy latin1_swedish_ci, czy coś tego typu to pozmieniaj na utf8.

https://dev.mysql.com/doc/refman/8.0/en/mysql-command-options.html

Jeśli robisz jakieś zmiany to spróbuj może zresetować bazę/server (włącz i wyłącz).

https://dev.mysql.com/doc/refman/8.0/en/charset-connection.html

Sprawdź też tym poleceniem, jakie kodowanie masz w bazie:

mysql> SHOW VARIABLES;
komentarz 15 maja 2018 przez CzarnYU_owca Nowicjusz (150 p.)

Hmm, więc tak.

Poprzestawiałem wszystko, co było LIKE latin (:D) do utf8 i nie przyniosło to żadnych efektów, to samo. Zresetować MySQL nie mogę, bo się przestawia znowu do latin :<
TU wstawiłem to, nad czym pracuję, może ja coś źle robię..

1
komentarz 16 maja 2018 przez CzarnYU_owca Nowicjusz (150 p.)

Dobra, rozwiązałem problem. Nie wiedziałem, że json_encode() może powodować ten problem. Już się więc dowiedziałem xD
Zamiast:

= json_encode($query->fetchAll());

powinno być:

= json_encode($query->fetchAll(), JSON_UNESCAPED_UNICODE);

 

komentarz 16 maja 2018 przez Chess Szeryf (76,710 p.)
Dzięki, że napisałeś jak rozwiązałeś problem, może przyda się dla "potomnych".

Podobne pytania

0 głosów
2 odpowiedzi 487 wizyt
0 głosów
2 odpowiedzi 238 wizyt
pytanie zadane 23 lipca 2016 w PHP przez MaciekM Użytkownik (990 p.)
0 głosów
2 odpowiedzi 1,021 wizyt

92,572 zapytań

141,422 odpowiedzi

319,643 komentarzy

61,959 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...