![]() |
![]() |
![]()
Post
#1
|
|
Grupa: Zarejestrowani Postów: 33 Pomógł: 1 Dołączył: 15.12.2005 Ostrzeżenie: (0%) ![]() ![]() |
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. Ten post edytował Kristof 14.07.2008, 22:34:21 |
|
|
![]() |
![]()
Post
#2
|
|
Grupa: Zarejestrowani Postów: 658 Pomógł: 95 Dołączył: 20.12.2005 Skąd: N54,35° E18,63° (Gdańsk) Ostrzeżenie: (0%) ![]() ![]() |
"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.) Ten post edytował b4x 14.07.2008, 22:38:51 |
|
|
![]()
Post
#3
|
|
Grupa: Zarejestrowani Postów: 33 Pomógł: 1 Dołączył: 15.12.2005 Ostrzeżenie: (0%) ![]() ![]() |
Rekordy wpisuje tak:
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":
Ten post edytował Kristof 14.07.2008, 23:09:31 |
|
|
![]()
Post
#4
|
|
Grupa: Zarejestrowani Postów: 286 Pomógł: 29 Dołączył: 5.04.2007 Skąd: Rymanów Zdrój/Rzeszów Ostrzeżenie: (0%) ![]() ![]() |
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 Ten post edytował bemol 15.07.2008, 09:33:10 |
|
|
![]()
Post
#5
|
|
Grupa: Zarejestrowani Postów: 33 Pomógł: 1 Dołączył: 15.12.2005 Ostrzeżenie: (0%) ![]() ![]() |
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
|
|
|
![]()
Post
#6
|
|
Grupa: Zarejestrowani Postów: 286 Pomógł: 29 Dołączył: 5.04.2007 Skąd: Rymanów Zdrój/Rzeszów Ostrzeżenie: (0%) ![]() ![]() |
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ż? |
|
|
![]()
Post
#7
|
|
Grupa: Zarejestrowani Postów: 616 Pomógł: 12 Dołączył: 16.07.2006 Skąd: : getCity ( ); Ostrzeżenie: (0%) ![]() ![]() |
Najlepiej to zakoduj sobie wprowadzany ciag znakow do bazy danych w base64 za pomoca funkcji:
base64_encode() np:
a przy pobieraniu danych dekoduj
to na pewno pomoze (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) |
|
|
![]()
Post
#8
|
|
Grupa: Zarejestrowani Postów: 33 Pomógł: 1 Dołączył: 15.12.2005 Ostrzeżenie: (0%) ![]() ![]() |
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 (IMG:http://forum.php.pl/style_emoticons/default/biggrin.gif) . Można zamknąć.
Ten post edytował Kristof 15.07.2008, 15:02:39 |
|
|
![]() ![]() |
![]() |
Aktualny czas: 24.08.2025 - 15:36 |