Oprettet ons. d. 26. maj 2010 kl. 16:40:42

1409
1409 (18.744 point. Point ude: 0)

Overførelse af æøå

Jeg har et lille script, der tilføjer noget tekst til mySQL-db. Dette er i en seperat fil:

IF($_POST['add']){
    $kunstner = $_POST["kunstner"];
    $titel = $_POST["titel"];
   
    mysql_connect("127.0.0.1","root");
    mysql_select_db("musik");
    $query = mysql_query("insert into samling (kunstner, titel)"."values('$kunstner','$titel')");
   
    $besked="Musik tilføjet";
    header("location: addmusic.php?besked=$besked");
}

På siden addmusic.php, med nogle indtastningsfelter osv., skal beskeden vises, men den vil ikke vise æøå?
Har også prøvet med ø, og så vises der intet efter "tilf"

ECHO $_GET['besked'];

Tak på forhånd!

Skrevet ons. d. 26. maj 2010 kl. 16:48:54| #1

splazz
splazz (55.958 point)
majbom.com
du er langt fra den første med det problem, hverken her eller på google...

du har problemer med dine tegnsæt, det skal være ens på alle dine filer, database og headers.

dvs at du skal have en header i dine filer der angiver tegnsættet for filen, filen skal være gemt i det tegnsæt og din databaseforbindelse skal bruge det tegnsæt.

f.eks. utf8 eller iso-8859-1

Skrevet ons. d. 26. maj 2010 kl. 16:49:40| #2

1409
1409 (18.744 point)
By the way:

addmusic.php har i head:

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

Skrevet ons. d. 26. maj 2010 kl. 17:24:12| #3

public2
public2 (18.835 point)
Jeg ved godt at det ikke er den kønneste eller bedste løsning, men havde selv samme problem for noget tid siden og før jeg fik rettet det hele til og havde tid til at finde alle de små fejl der gjorde, så lavede jeg denne metode:

function convertChar($stringToEdit) {
   
$search = array("æ","ø","Ã¥","Æ", "Ø", "Ã...","Ja","æ","ø","å","Æ", "Ø", "Å");
$replace = array("&aelig;","&oslash;","&aring;","&AElig;","&Oslash;", "&Aring;","&aelig;","&oslash;","&aring;","&AElig;","&Oslash;", "&Aring;");$text = str_replace($search, $replace, $stringToEdit);
return $text;

Men jeg ville forsøge at gøre som splazz siger og rette fejlen i dine charset, men ellers er du velkommen til at bruge koden overstående indtil da

Skrevet ons. d. 26. maj 2010 kl. 17:40:36| #4

aners
aners (23.066 point)
phpMyAdmin > Collation

Skrevet tor. d. 27. maj 2010 kl. 08:48:31| #5

1409
1409 (18.744 point)
Det at db'en skal bruge det rigtige charset vha. kollation er jeg med på...

Men hvis vi glemmer det, så kan jeg ikke forstå, at min besked, der sender med header'en, ikke vises korrekt.

Her er hele koden:
addmusic.php:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ (...)
<html xmlns="http://www.w3.org/ (...)
<head>
<link rel="stylesheet" type="text/css" href="music.css">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Tilføj musik</title>
</head>

<body>
<form action="action.php" method="post">
Kunstner: <input type="text" name="kunstner" id="kunstner" /><br />
Titel: <input type="text" name="titel" id="titel" /><br />
Klik på knappen: <input type="submit" name="add" id="add" value="- Tilføj -" />

</form>
<?php
ECHO $_GET['besked'];
?>

<br />
</body>
</html>


action.php:
IF($_POST['add']){
    $kunstner = $_POST["kunstner"];
    $titel = $_POST["titel"];
   
    mysql_connect("127.0.0.1","root");
    mysql_select_db("musik");
    $query = mysql_query("insert into samling (kunstner, titel)"."values('$kunstner','$titel')");
   
    $besked="Musik tilføjet";
    header("location: addmusic.php?besked=$besked");
}

Skrevet tor. d. 27. maj 2010 kl. 13:48:01| #6

olebole
olebole (214.028 point)
<ole>

1) Hvilket tegnsæt gemmer du dine filer med?
2) Hvilket tegnsæt sender din server dokumenterne med?

/mvh
</bole>

Skrevet tor. d. 27. maj 2010 kl. 14:31:58| #7

1409
1409 (18.744 point)
Der ser ud til at det umiddelbare problem er løst, nemlig ved at sørge for, at filerne er gemt med utf-8. Og nu vises det korrekt.

Med phpinfo finder jeg: HTTP_ACCEPT_CHARSET     ISO-8859-1,utf-8;q=0.7,*;q=0.7

Jeg ved ikke om det er det rigtige...

Men mht. db'en får jeg faktisk underlige tegn i selve db'en, som jeg ser den vha. phpMyAdmin - selvom den er oprettet med CHARSET=utf8 COLLATE=utf8_unicode_ci og den enkelte table med COLLATE utf8_unicode_ci.

Skrevet tor. d. 27. maj 2010 kl. 17:21:34| #8

splazz
splazz (55.958 point)
majbom.com
så kan det være at din databaseforbindelse ikke er utf8, prøv at sætte den til det med

mysql_set_charset('utf8');

Skrevet fre. d. 28. maj 2010 kl. 14:03:55| #9

1409
1409 (18.744 point)
Tak til olebole og splazz!

IF($_POST['add']){
    $kunstner = $_POST["kunstner"];
    $titel = $_POST["titel"];
   
    mysql_connect("127.0.0.1","root");
    mysql_select_db("musik");
   
    mysql_set_charset("utf8");
    $query = mysql_query("insert into samling (kunstner, titel)"."values('$kunstner','$titel')");
   
    $besked="Musik tilføjet";
    header("location:addmusic.php?besked=$besked");
}

Det medførte, at også når jeg henter data fra db'en, skal mysql_set_charset("utf8") bruges.

Jeg fandt i øvrigt også ud af, at mySQL kan konfigureres til utf8 som standard inde i my.ini.

Smid svar...

Skrevet fre. d. 28. maj 2010 kl. 20:43:11| #10


Skrevet søn. d. 30. maj 2010 kl. 20:02:16| #11


Skriv et indlæg




Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] [img]link til billede[/img]
Web- og emailadresser omdannes automatisk til links

Log ind

   

   

Seneste spørgsmål

Udtræk af enkelte felter fra bestemte kolonner i mysql

Oprettet den 11. februar 2012 kl. 19.27
hrole giver 30 point for svar | Giv et svar »

Procentregning

Oprettet den 11. februar 2012 kl. 11.26
sevinding giver 60 point for svar | Giv et svar »

Ville ikke tildele at upload det til database eller komme...

Oprettet den 10. februar 2012 kl. 21.23
tobrukDk giver 15 point for svar | Giv et svar »

Seneste guides

Installer win 7
Den gode bruger


   




Tips & Tricks fra PC World

Teaser billede

Her er fem sjove danske websider du skal kende

Trænger dine lattermuskler til en omgang fitness på dansk? Vi viser vej til fem websider fyldt med humor og vanvittig satire.


Anmeldelser fra PC World

Teaser billede

Test: Denne super-tablet er iPads hårdeste konkurrent

Eee Pad Transformer Prime er frygtindgydende med sin quadcore processor og evne til at trylle sig om til bærbar. Apple bør kigge i bagspejlet, for Asus' tablet-pc kommer buldrende - og gør det...


Seneste blogindlæg

Teaser billede

Tvangslukke spørgsmål: Hvad er den bedste løsning?

Hej Vi har mange åbne spørgsmål på Eksperten. Vi ville gerne tvangslukke dem - så et spørgsmål efter f.eks. 6 måneder lukkes. Men der er et par uklarheder som ville være gode at få lidt input til:...


Nyheder fra PC World

Teaser billede

Nu kan du snart hente Windows 8

Den nye offentlige betaversion af Windows 8 er klar i denne måned.


Nyheder fra Computerworld

Teaser billede

Måske snart slut med Androids helt store problem

Android-platformen har længe været plaget af et særligt problem. Men måske er problemet nu ved at være elimineret.


Kurser
Samarbejdspartnere

Udgiver · © 2012 IDG Danmark A/S · Hørkær 18 · 2730 Herlev · Tlf.: 77 300 300 · Fax: 77 300 301 · Brug af personoplysninger