Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [MYSQL] Złe kodowanie
Forum PHP.pl > Forum > PHP
daniel1302
Witam, szukałem na forum i w necie lecz nic nie pomaga
Skrypty koduje:UTF-8
System kodowania znaków dla MySQL: UTF-8 Unicode (utf8)
System porównań dla połączenia MySQL: utf8_unicode_ci

Odczytuje tak: Zmieniono pogod�?!
Zapisuje tak: Zmieniono pogodÄ?!

Już 2 dzień próbuje zrobić coś z tym problemem.
Dziękuje za pomoc
bogdan89
  1. <?php
  2. mysql_query ('SET NAMES utf-8');
  3. ?>

spróbuj wykonać to zapytanie zaraz po połączeniu z bazą danych

poza tym było na forum, i to nie raz smile.gif
skowron-line
http://pl.php.net/manual/pl/function.iconv.php
daniel1302
Nic nie pomaga- pracuje na webservie
Dałem to i to zapytanie zaraz pod mysq_select_db
iconv("ISO-8859-2","UTF-8",$load['text'])

Proszę o pomoc.
Na forum szukałem i nic
_olo_1984
wygląda na to, że masz problem z odczytem. Napewno skrypt pobierający dane jest zakodowany w utf-8. Mi to wygląda jakby nie był. Ale mogę się mylić. A sprawdzałeś na różnych przeglądarkach ? Też mam w domu webserv i wsio śmiga (na utf-8).
daniel1302
Jest to na wszystkich przeglądarkach
Skrypt napewno jest w UTF-8
Teraz looknołem do pliku my.ini

i jest to
Kod
#WebServ - SKASOWANIE TEJ LINI OD GROZI RESTARTEM USTAWIEN!!!
#Uncomment or Add only the keys that you know how works.
#Read the MySQL Manual for instructions

[mysqld]
basedir=D:/Program Files/WebServ/mysql
#bind-address=
datadir=D:/Program Files/WebServ/mysql/data
language=D:/Program Files/WebServ/mysql/share/polish
#slow query log#=
tmpdir=D:/Program Files/WebServ/temp
port=3306
#set-variable=key_buffer=16M
character-set-server=latin2
default-character-set=latin2

pomimo iż w phpmyadmin jest utf8
jarmiar
dobrym nawykiem jest kodowanie wprowadzanego ciągu znaków w base64_encode() a przy pobieraniu dekodowanie za pomocą funkcji base64_decode() to rozwiązuje problemy z polskimi znakami

pozdrawiam
daniel1302
Musze to podczas kazdego odczytywania i zapysywania danych tosz to gorsze niz w maskowskiej rzezni?
Skie
Nie musisz. Użyj tego SET NAMES latin2 zaraz po nawiązaniu połączenia z bazą (host, baza, hasło, user).
Przed następnymi zapytaniami (INSERT, SELECT, DELETE, UPDATE etc.) nie musisz już tego ponownie robić.
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.