XHTMLforum

XHTMLforum (http://xhtmlforum.de/index.php)
-   Javascript & Ajax (http://xhtmlforum.de/forumdisplay.php?f=83)
-   -   php-generierte xml-Daten werden vom IE nicht interpretiert (http://xhtmlforum.de/showthread.php?t=51660)

esviko 03.05.2008 00:32

php-generierte xml-Daten werden vom IE nicht interpretiert
 
Hi all!
Habe ein Formular geschrieben, bei dem durch onChange() eines select-Feldes die Optionen eines weiteren select-Feldes generiert werden sollen. Die Daten hierfür werden aus einer MySQL-Tabelle gelesen. Mit Hilfe von PHP werden XML-Daten generiert, die dann per AJAX an den Browser übergeben werden.
Die ganze Sache funzt im FF, aber der IE macht nicht mit. Das Problem entsteht an folgender Stelle:
übergebe ich dem IE eine fertige xml-Datei, so funktioniert er, wie ich es von ihm erwarte
(ich nutze für den HttpRequest die XHConn library)
myConn.connect("getPlaces.xml", "GET", "IDDistrict="+IDDistrict, fnWhenDone);

übergebe ich ihm aber von PHP generierte xml-Daten, so spielt er nicht mit
myConn.connect("getPlaces.php", "GET", "IDDistrict="+IDDistrict, fnWhenDone);

in der getPlaces.php habe ich natürlich den header auf Content-type: text/xml; gesetzt
<?PHP header('Content-type: text/xml; charset=utf-8'); ... ?>

Hat jemand eine Idee, woran das liegen könnte?
Danke im Voraus!

Gruß
esviko

kampfgnom 03.05.2008 11:18

kannst du evtl mal den richtigen source code posten...da kann man meist mehr mit anfangen!!

esviko 03.05.2008 12:47

Die Idee:
im 1. select-Feld wähle ich eine Kreistadt. Der Inhalt des 2. select-Feldes wird durch die Wahl des 1. Feldes bestimmt. Hier kommen die zu der Kreisstadt gehörenden Orte rein. Den Job soll AJAX (XHConn library) mit Unterstützung von PHP und MySQL erledigen.

Code:

<!-- 1. select-Feld - enthält die Kreisstädte -->
<select name="district" size="1" onchange="getPlaces(this.value)">
        <option value="2">Höxter</option>
        <option value="20">Paderborn</option>
        <option value="24">Lippe</option>
</select>

<!-- 2. select-Feld - wird von AJAX/PHP generiert bei Auswahl einer Kreisstadt -->
<select id="selectPlaces" name="place" size="1">
        <option> </option>
</select>

Die JavaScriptFunktion 'getPlaces()' übergibt per 'GET' die ID des Kreises an die getPlaces.php, die wiederum durch eine SQL-Abfrage XML-Daten generiert und diese an die 'getPlaces()' zurückgibt. Die XML-Daten werden per JavaScript geparst und in die HTML-Struktur eingebunden.

getPlaces.php sieht in etwa so aus:
PHP-Code:

<?PHP
header
('Content-type: text/xml; charset=utf-8');

/* SQL-Abfrage... speichert das Ergebnis in der $optionPlaces */

print $optionPlaces;
?>

Die von der getPlaces.php generierten XML-Daten sehen in etwa so aus:
Code:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<places>
        <place>
                <placeName>Höxter</placeName>
                <placeID>21</placeID>
        </place>
        <place>
                <placeName>Brakel</placeName>
                <placeID>22</placeID>
        </place>
        <place>
                <placeName>Bad Driburg</placeName>
                <placeID>23</placeID>
        </place>
</places>

die 'getPlaces()' sieht so aus:
Code:

function getPlaces(IDDistrict) {
        var myConn = new XHConn();
        var selectPlaces = document.getElementById('selectPlaces');

        var fnWhenDone = function(oXML) {
                var myXML = oXML.responseXML;
               
                for(i=0; i<myXML.getElementsByTagName('place').length; i++){


                        var place = myXML.getElementsByTagName('place')[i];
                        var placeName = place.getElementsByTagName('placeName')[0].firstChild.data;
                        var placeID = place.getElementsByTagName('placeID')[0].firstChild.data;

                        var newOPTIONText = document.createTextNode(placeName);
                        var newOPTION = document.createElement("option");
                       
                        selectPlaces.appendChild(newOPTION);
                        newOPTION.setAttribute('value', placeID);
                        newOPTION.appendChild(newOPTIONText);       
                }
        }
        if (!myConn) alert("XMLHTTP not available. Try a newer/better browser.");
        myConn.connect("getPlaces.php", "GET", "IDDistrict="+IDDistrict, fnWhenDone);
}

Der Witz ist nun folgender...
Wenn ich die XML-Daten nicht von der getPlaces.php generieren lasse, sondern der getPlaces() eine fertige XML-Datei übergebe
Code:

myConn.connect("getPlaces.xml", "GET", "IDDistrict="+IDDistrict, fnWhenDone);
dann kann der IE damit umgehen, sprich, der IE erhält dann ein Objekt, dass nicht null ist.

Meine Vermutung ist, dass der IE Dateien, die keine xml-Endung haben, schlicht und ergreifend nicht als xml-Dateien behandeln will... selbst wenn der Webserver ihm über den Header mitteilt, dass es sich um XML-Daten handelt.

Habe auch versucht, die getPlaces.php (in der die XML-Daten generiert werden) in getPlaces.xml umzubenennen, und dann dem Server über .htaccess mitzuteilen, dass er doch bitte xml-Dateien wie php-Dateien behandeln soll. Aber da macht anscheinend mein Provider nicht mit...

kampfgnom 03.05.2008 16:22

versuch doch mal heruaszufinden, welche header er bei der *.xml datei mitsendet!

esviko 03.05.2008 16:38

verdammt, du hast recht... hier scheint das Problem zu liegen
hier der Header
Code:

GET /erziehungswissenschaft/bsc/admin/content/ajax/getPlaces.php?IDDistrict=20 HTTP/1.1
Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/x-shockwave-flash, application/x-silverlight, */*
Accept-Language: de
UA-CPU: x86
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; .NET CLR 2.0.50727; .NET CLR 1.1.4322)
Host: groups.uni-paderborn.de
Connection: Keep-Alive
Cookie: PHPSESSID=4e1c37e29c88f38c94xxxxxx

HTTP/1.1 200 OK
Date: Sat, 03 May 2008 14:31:19 GMT
Server: Apache
Expires: Thu, 19 Nov 1981 08:52:00 GMT
Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0
Pragma: no-cache
Content-Length: 314
Keep-Alive: timeout=15, max=100
Connection: Keep-Alive
Content-Type: text/html; charset=utf-8

als Content-Type gibt er doch tatsächlich text/html an... Aber wie kann ich dazu zwingen, text/xml anzugeben???

esviko 03.05.2008 22:26

Hi Kampfgnom!

Habe die Lösung zu meinem Problem gefunden... Jetzt würde ich die Lösung noch gern verstehen!
Meine getPlaces.php sah eigentlich so aus:
PHP-Code:

<?PHP
header
('Content-type: text/xml; charset=utf-8');
session_start();
include(
'session.php');
include(
'db.connect.php');

/* SQL-Abfrage ... speichern in $optionPlaces */

echo $optionPlaces;
?>

in der 2. Zeile starte ich eine Session
in der 3. Zeile include ich eine datei, die überprüfen soll, ob der User eingelogt ist

Nachdem ich die 2. und 3. Zeile gelöscht habe, steht im Header, den der Webserver an den Client sendet
Code:

Content-Type: text/xml; charset=utf-8
und der IE verhält sich so, wie ich es von ihm erwarte.
Als die 2. und 3. Zeile noch da waren meldete der Server dem Client immer
Code:

Content-Type: text/html; charset=utf-8
Danke jedenfalls für deine Anteilnahme und deine Hilfe! ... bis zum nächsten Problem...

Gruß
esviko

esviko 09.05.2008 14:46

Thanx fordfan!
After removing the session_start() the IE is working fine :D


Alle Zeitangaben in WEZ +2. Es ist jetzt 04:43 Uhr.

Powered by vBulletin® Version 3.8.11 (Deutsch)
Copyright ©2000 - 2024, vBulletin Solutions, Inc.

© Dirk H. 2003 - 2023