Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Cudzysłów
Forum PHP.pl > Forum > Przedszkole
nexosg
Witam
Mam problem z cudzy słowami
Zrobiłem stronkę która łączy się z mysql-em i umożliwia update rekordów tabeli
do formularza w którym są wpisywane dane wysyłam rekord w ten sposób:

echo "<td><a href=\"edit.php?id={$r['id']}&id={$r['tekst']}

jednak gdy w tekst pojawi się cudzysłów to w polu odpowiadającym widzę tylko ; podczas gdy w bazie jest dłuższy tekst.
Gdy robię updte tekstu z cudzysłowem jest wszysko ok.

Co zrobić aby cudzysłów w polu teskt był widzoczny normalnie?

Pozdrawiam
nowotny
Nie qmam... podaj jakiś konkretny przykład... i naucz się stosować urlencode" title="Zobacz w manualu PHP" target="_manual...
em1X
Użyj htmlspecialchars" title="Zobacz w manualu PHP" target="_manual wobec danych wyświetlanych z bazy.
nexosg
Przykład"
rekord przed update: Ala ma kota.
pekord po update: Ala ma "kota.
I przy ponownym update wszystko mi się wywala bo widze albo ;, albo Ala ma...

Jak użyć htmlspecialchar w tej funkcji?


function konwertuj($tekst) {
$win = array("ą","ć","ę","ł","ń","ó","ś","ź","ż", "Ą","Ć","Ę","Ł","Ń","Ó","Ś","Ź","Ż","Ä™", "Ĺş", "\"");
$uni = array("ą","ć","ę","ł","ń","ó",
"ś","ź","ż","Ą","Ć","Ę",
"Ł","Ń","Ó","Ś","Ź","Ż","ę","ź", "&quot;");
for ( $i=0; $i < count($win);$i++) $win[$i]="/".$win[$i]."/";
$tekst = preg_replace($win, $uni, $tekst);
return($tekst);
}

Bo po update mnożą mi się \



----

Może trochę inaczej.

Macie może jakiś manual gdzie jest opisane wszystko jak zrobić stronkę w php/mysql (insert/update/delete) żeby się poprawnie wyświetlały znaki polskie. Bo po insertach i update w różnych prezeglądarkach różnie wyglądają.
em1X
Cytat(nexosg @ 4.02.2008, 15:25:38 ) *
Macie może jakiś manual gdzie jest opisane wszystko jak zrobić stronkę w php/mysql (insert/update/delete) żeby się poprawnie wyświetlały znaki polskie. Bo po insertach i update w różnych prezeglądarkach różnie wyglądają.


ehhh.. to jest po prostu Twoja niewiedza. Jeżeli kodowanie na stronie, z której dane są wysyłane do bazy, ustawisz na UTF-8, bazie danych każesz się łączyć z kodowaniem UTF-8 i zapisywać w niej dane również w UTF-8 to przy wyświetlaniu danych na stronie z tym kodowaniem polskie znaki będą zachowane.

Twoje krzaki wynikają z różnic kodowania:
1) formularz -> baza, lub,
2) baza -> strona www

Nie ma potrzeby używania jakichkolwiek śmiesznych funkcji typu konwertuj jeżeli kodowanie na każdej linii będzie zachowane takie samo.

Co do [manual\]htmlspecialchars\[/manual\]. Naturalnie, że jeżeli tekst w bazie będzie posiadał " to przeglądarka uzna to jako koniec pola, które ma zawierać treść.
Załóżmy, że w bazie masz:
Kod
Ala" ma kota


Jeżeli wstawimy to do pola tekstowego, wyjdzie nam z tego taki kod:
  1. <input type="text" name="pole" value="Ala" ma kota />


czyli " ma kota" ginie bo jest poza value="".

W PHP więc powinno wyświetlanie wyglądać tak:
  1. <?php
  2. print '<input type="text" name="pole" value="'.htmlSpecialChars($dane_z_bazy).'" />';
  3. ?>
nowotny
Cytat(nexosg @ 4.02.2008, 15:25:38 ) *
Przykład"
rekord przed update: Ala ma kota.
pekord po update: Ala ma "kota.
I przy ponownym update wszystko mi się wywala bo widze albo ;, albo Ala ma...

Ja jakoś dalej tego nie widze... :/


Cytat(nexosg @ 4.02.2008, 15:25:38 ) *
Macie może jakiś manual gdzie jest opisane wszystko jak zrobić stronkę w php/mysql (insert/update/delete) żeby się poprawnie wyświetlały znaki polskie. Bo po insertach i update w różnych prezeglądarkach różnie wyglądają.

Robi się normalnie... trzeba tylko uważać żeby kodowanie strony, pliku i bazy się zgadzało... a jak chcesz przesyłać tekst ze specjanlymi znakami poprzez URL to używaj funkcji urlencode" title="Zobacz w manualu PHP" target="_manual, chociaż to w ogóle poroniony pomysł jest IMHO...
dziurson
Nalepiej wsawić po połączeniu taką linię:

  1. <?php
  2. mysql_query("SET NAMES latin1");
  3. ?>


za latin1 wstaw kodowanie twojej tabeli
nexosg
1. Wiem że moja nie wiedza. Nigdy nie pisałem w php. Robię to pierwszy raz i nawet nigdy mnie do tego języka nie ciągnęło. Ale muszę.

2. Wiem że kodowanie. Z tym że nie wiem jak to poustawiać.

Potrzebuję jakiś sensowny opis jak to zrobić
em1X
Cytat(dziurson @ 4.02.2008, 15:38:05 ) *
Nalepiej wsawić po połączeniu taką linię:

  1. <?php
  2. mysql_query(&#092;"SET NAMES latin1\");
  3. ?>


za latin1 wstaw kodowanie twojej tabeli


Standardem jest UTF8. Trzymajmy się standardów:

  1. <?php
  2. mysql_query('SET CHARACTER SET utf8');
  3. mysql_query('SET NAMES utf8');
  4. ?>


Napisałem dokładnie jak to zrobić. Przeczytaj ponownie.
nexosg
Ojej właśnie o coś takiego mi chodziło. Dzięki.

Pozdrawiam
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.