Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [PHP][MYSQL] Polskie znaki...
Forum PHP.pl > Forum > Przedszkole
Kristof
Wiem że temat polskich znaków był poruszany tysiące razy jednak nic z tego nie rozwiązuje mojego problemu.

System: PHP 5.2.4; Mysql 5.0.45

Problem jest natury następującej. W skrócie to poprostu w bazie danych nie zapisują sie polskie znaki a nawet jak recznie zmienie w phpmyadmin to i tak na stronie nie będą odczytane prawidłowo tylko jako "?" i tak samo są zapisywane. Jest to nowa strona nie kopiowana baza z innego serwera tylko tworzona od podstaw na localhoscie (windows). Kodowanie bazy danych jest ustawione na latin2_general_ci strona w formacie "charset=iso-8859-2". Jednak to nie koniec. Niektóre tabelki mają zmienione kodowanie na latin1 ,ponieważ muszą takie być, gdyż hasła sa kodowane w md5 i inaczej się nie da. Jeżeli wymusze przy połączeniu z bazą zmiane kodowanie na latin2 to i owszem pojawiają się polskie znaki wszystko niemal jest ok jednak znów pojawia się problem z hasłami i nie da się wtedy zalogować. Więc to odpada. Spotkałem się z tym pierwszy raz być może jak przeniose strone na inny serwer będzie dobrze ale nie moge ryzykować "moze" i musze to rozwiązać najpierw u siebie. Dziękuje za wszelkie odpowiedzi.
b4x
"Niektóre tabelki mają zmienione kodowanie na latin1 ,ponieważ muszą takie być, gdyż hasła sa kodowane w md5 i inaczej się nie da"

Nigdy o tym nie słyszałem, żeby hasła w md5 wymagały latin1.

A co do twojego problemu, hmm... byś pokazał jakiś przykładowy rekord z bazy. (I jak np. zapisujesz go.)
Kristof
Rekordy wpisuje tak:

  1. <?php
  2. function sqlesc($x) {
  3. return "'".mysql_real_escape_string($x)."'";
  4. }
  5.  
  6. $nazwisko = sqlesc($_POST["nazwisko"]);
  7. mysql_query("INSERT INTO users (nazwisko) VALUES($nazwisko)");
  8. ?>


  1. --
  2. -- Struktura tabeli dla `users`
  3. --
  4.  
  5. CREATE TABLE `users` (
  6. `id` int(10) UNSIGNED NOT NULL AUTO_INCREMENT,
  7. `passhash` varchar(32) character SET latin1 collate latin1_bin NOT NULL,
  8. `secret` varchar(20) character SET latin1 collate latin1_bin NOT NULL,
  9. `nazwisko` text
  10. ) ENGINE=MyISAM DEFAULT CHARSET=latin2;
  11.  
  12.  
  13. -- Zrzut danych tabeli `users`
  14. --
  15.  
  16. INSERT INTO `users` (`nazwisko`) VALUES ('Ko?cielny');


Oczywiście to wszystko obciąłem, tylko przykład, w rzeczywistościmtego wszystkiego jest więcej. A co do md5 masz racje bo to nie tylko md5 używam tylko tworze taki ciag znakow secret do porównywania i to on wymaga latin1 oto funkcja do tego "sekretu":

  1. <?php
  2. function mksecret($len = 20) {
  3. $ret = "";
  4. for ($i = 0; $i < $len; $i++)
  5. $ret .= chr(mt_rand(0, 255));
  6. return $ret;
  7. }
  8. ?>
bemol
Więc jeśli chodzi o kodowanie to:
1. Sprawdz jakie kodowanie ma program w którym piszesz. Jeśli jest to notatnik to radzę zmienić, bo iso-8859-2 ma z nim problemy (a raczej on z nim ;p)
2. Jeśli to nie jest windowsowy notatnik to sprawdź jakie kodowanie ma program. Polecam PSpad tam ładnie wszystko i prosto mozna zmienic.
3. Przez to ze dane zostały zle wpisane (zle kodowanie programu) do bazy danych, to i zle sa wyswietlane.
4. jesli problemem był tylko program to po zmianie jego kodowania powinno wszystko grac.
jesli nie to idziemy dalej:
5. sprawdz wszystkie pliki (najwazniejsze: plik dodawania do bazy, plik wyswietlania) i ich kodowanie. jesli sie nie zgadzaja to znalezlismy problem, jesli sa w porzadku to sprobuj wpisać jeszcze raz dane do bazy.
ściągnij to i skonfiguruj i wyślij na serwer, a później tylko wejdz w plik import.php
Kristof
Bemol chyba małe niporozumienie zaszło. Ja nie wpisuje przez notatnik ani nic podobnego do bazy z pliku tylko idzie przez formularz (można było zobaczyć $_POST w przykładzie). I Dodam że jeżeli wyświetle tą zmienną którą chce dodać do bazy przed samym dodaniem to ona wygląda ok z polskimi znakami a linijke potem, gdzie dodawana jest do bazy to w bazie już jest bez polskich znaków
bemol
dokładnie - małe nie porozumienie.

tak chodzi o formularz i dodawnie z formularza, ale te formularz przypuszczam ze jest umieszczony w jakimś pliku, a ten plik został w czymś napisany, nieprawdaż?
jarmiar
Najlepiej to zakoduj sobie wprowadzany ciag znakow do bazy danych w base64 za pomoca funkcji:

base64_encode()

np:
  1. <?
  2. $tekst = "Tekst z polskimi znakami ąęśżźćółńć hgfhgf";
  3.  
  4. $tekst = base64_encode($tekst);
  5.  
  6. //zapyyanie do bazy danych
  7. ?>



a przy pobieraniu danych dekoduj
  1. <?
  2.  
  3. //zapytanie pobierajace dane z bazy
  4.  
  5. $tekst = base64_decode($tekst);
  6.  
  7. echo $tekst;
  8.  
  9.  
  10.  
  11. ?>



to na pewno pomoze smile.gif
Kristof
Jarmiar jest to może troszke kłopotliwe ale pomaga tak jak trzeba. Dziekuje wszystkim co próbowali i temu co ostatecznie rozwiązał problem biggrin.gif. Można zamknąć.
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.