ugrás a tartalomhoz

Ajaxos eseménynaptárnál karakterkódolási hiba, mysql ba..

dc-hungary · 2008. Ápr. 20. (V), 19.57
Üdv!

Van egy ajaxos eseménynaptáram, de annyi problémám van vele, hogy az ékezetes betűket így írja be az adatbázisba:

űűűáááééúúő helyett ŹŹŹåååÊÊúúĹ�

az adatbázisba, ahol a szöveget tárolom, annak a mezőnek a karakterkódolása: latin2_general_ci
Hozzá kell tenni, hogy máshol jó az ékezet, csak ennél nem, de ha én írom be a phpmyadminba az ékezetes betűt, akkor jól jeleníti meg.
Szóval a beírással van a gond. na igen, ez úgy működik hogy egyik php átadja a másiknak a beírt szöveget ajax-al.
és én arra gyanakszok, hogy itt rontja el az ékezeteket..

Próbáltam már a lekérdezésnél UTF8 , LATIN2 , stb.. de egyikel se lett jó.
Szóval a beírást kéne megcsinálni, hogy ékezetesen írja be..

Kiszedtem a scriptből, így csak azt osztom meg, ami ehhez szükséges:


index.php (form):
		<div style="display: none; margin-top: 10px;" id="addEventForm">
			<b>Új esemény</b>
			<br>
			Date: <input type="text" size="2" id="evtDay" disabled> <input type="text" size="2" id="evtMonth" disabled> <input type="text" size="4" id="evtYear" disabled>
			<br>
			<textarea name="szoveg" id="evtBody" cols="32" rows="5"></textarea>
			<br>
			<input type="button" value="Új esemény" onClick="addEvent($F('evtDay'), $F('evtMonth'), $F('evtYear'), $F('evtBody'));">
		</div>
index.php (javascript):
<script type="text/javascript">
	function highlightCalendarCell(element) {
		$(element).style.border = '1px solid #999999';
	}

	function resetCalendarCell(element) {
		$(element).style.border = '1px solid #000000';
	}
	
	function startCalendar(month, year) {
		new Ajax.Updater('calendarInternal', 'rpc.php', {method: 'post', postBody: 'action=startCalendar&month='+month+'&year='+year+''});
	}
	
	function showEventForm(day) {
		$('evtDay').value = day;
		$('evtMonth').value = $F('ccMonth');
		$('evtYear').value = $F('ccYear');
		
		displayEvents(day, $F('ccMonth'), $F('ccYear'));
		
		if(Element.visible('addEventForm')) {
			// do nothing.
		} else {
			Element.show('addEventForm');
		}
	}
	
	function displayEvents(day, month, year) {
		new Ajax.Updater('eventList', 'rpc.php', {method: 'post', postBody: 'action=listEvents&&d='+day+'&m='+month+'&y='+year+''});
		if(Element.visible('eventList')) {
			// do nothing, its already visble.
		} else {
			setTimeout("Element.show('eventList')", 300);
		}
	}
	
	function addEvent(day, month, year, body) {
		if(day && month && year && body) {
			// alert('Add Event\nDay: '+day+'\nMonth: '+month+'\nYear: '+year+'\nBody: '+body);
			new Ajax.Request('rpc.php', {method: 'post', postBody: 'action=addEvent&d='+day+'&m='+month+'&y='+year+'&body='+body+'', onSuccess: highlightEvent(day)});
			$('evtBody').value = '';
		} else {
			alert('There was an unexpected script error.\nPlease ensure that you have not altered parts of it.');
		}
		
		// highlightEvent(day);
	} // addEvent.
	
	function highlightEvent(day) {
		Element.hide('addEventForm');
		$('calendarDay_'+day+'').style.background = '#<?= $eventColor ?>';
	}
	
	function showCP() {
		Element.show('cpBox');
	}
	
	function deleteEvent(eid) {
		confirmation = confirm('Are you sure you wish to delete this event?\n\nOnce the event is deleted, it is gone forever!');
		if(confirmation == true) {
			new Ajax.Request('rpc.php', {method: 'post', postBody: 'action=deleteEvent&eid='+eid+'', onSuccess: Element.hide('event_'+eid+'')});
		} else {
			// Do not delete it!.
		}
	}
</script>
rpc.php (beszúrás az adatbázisba):
	case 'addEvent':
		$day = $_POST['d'];
		$month = $_POST['m'];
		$year = $_POST['y'];
		$body = $_POST['body'];
		
		$timeStamp = mktime(0,0,0, $month, $day, $year);
		$bodyF = addslashes(trim($body));
		mysql_query("INSERT INTO event (text, timestamp) VALUES ('$body', '$timeStamp')");
		break;
rpc.php (lekérdezés, a SET NAMES-nál már többel is próbálkoztam, és egyik se lett jó.. [LATIN2, UTF8]):
case 'listEvents':
		$day = $_POST['d'];
		$month = $_POST['m'];
		$year = $_POST['y'];
		
		$timeStamp = mktime(0,0,0, $month, $day, $year);
		
		$eventQuery = mysql_query("SET NAMES `LATIN2` COLLATE `latin2_general_ci`");
		$eventQuery = mysql_query("SELECT id, text FROM event WHERE timestamp='$timeStamp' ORDER BY id DESC");
		if($eventQuery) {
			if(mysql_num_rows($eventQuery) >0) {
				echo '<br><b>Események a következő napra: '. date("Y", $timeStamp) .'/'. date("m", $timeStamp) .'/'. date("d", $timeStamp) .'</b>';
				for($i=0; $i<mysql_num_rows($eventQuery); $i++) {
					if($i % 2) { $bgColor = '#'. $iteratorColor1 .''; } else { $bgColor='#'. $iteratorColor2 .''; }
					extract(mysql_fetch_array($eventQuery), EXTR_PREFIX_ALL, 'e');
					
					if($_SESSION[admin_session] == "true") {
						echo '<div style="background-color: '. $bgColor .'; margin-bottom: 4px; padding: 1px;" id="event_'.$e_id.'">
								<div>
									'. nl2br($e_text) .'
								</div>
								<div style="font-size: 9px;">
									<span style="color: blue; text-decoration: underline; cursor: pointer;" onClick="deleteEvent('.$e_id.')">
										Delete this event
									</span>
								</div></div>';
					} else {
						echo '<div style="background-color: '. $bgColor .'; margin-bottom: 4px; padding: 1px;">
								'. nl2br($e_text) .'
							</div>';	
					}
				} // for.
			} else {
				echo 'Erre a napra nincs esemény bejegyezve!';
			}
		} else {
			echo 'Hiba az adatok lekérdezésekor!';
		}
		
		break;
próbálkoztam
<meta content="text/html; charset=ISO-8859-2" http-equiv="content-type">
-al is, de nem változtatott a problémán..


Mi lehet a probléma?
 
1

Karakterkódolás

janoszen · 2008. Ápr. 20. (V), 20.07
Lehet, hogy triviális, de a következők megvannak?

  • Az AJAXot hívó oldalt UTF-8-ban küldöd ki?
  • A mindenféle RPC-k UTF-8 headerrel mennek ki?
  • A tábla karakterkódolása UTF-8?
  • Az adatbázis kapcsolat kódolása UTF-8?


Ha ez mind megvan, akkor elvileg jól kellene menjen. Vegyes karakterkódolásokkal már több baj van.
2

thx

dc-hungary · 2008. Ápr. 20. (V), 20.52
Thanks, megoldottam :)
teljesen átalakítottam, kiszedtem belőle az ajax részt és mostmár tökéletes