xml geçerliliği, ajax ve php

3 Cevap php

Ben ajax PHP Javascript bazı XML dönen ve bazı 'geçersiz xml' hataları alıyorum. Xml Bu gibi görünüyor dönüyorum:

<response>
<song>tdb2009-01-29s2s06</song>
<song>tdb2009-01-29s1s02</song>
</response>

Ve bunu ayrıştırmak için benim javascript gibi görünüyor:

 function u_handleServerResponse(){  
   //pull xml from xml response  
   var xmlResponse = xmlHttp.responseXML;

   //check to see if xml was pulled
   if(!xmlResponse || !xmlResponse.documentElement){
     throw("Invalid XML Structure:\n" + xmlHttp.responseText);
   }

   //this is for catching errors with firefox
   var rootNodeName = xmlResponse.documentElement.nodeName;

   //check for errors
   if(rootNodeName == "parsererror"){
     throw("Invalid XML Strucutre");
   }

   //get the root
   xmlRoot = xmlResponse.documentElement;

   var songArray = xmlRoot.getElementsByTagName("song");

  for(var i = 0; i < songArray.length; i++){   
   etc., etc...

Ve ben alıyorum bir

Yanıtı okuma hatası: Geçersiz XML strucutre

hatası. Tüm bu sizin için doğru görünüyor mu? Xml yanlış veya yanlış yüklenen ediliyor? Tüm yardım büyük beğeni topluyor. Şimdiden teşekkürler ...

3 Cevap

Bir xml başlığını da gerekebilir ...

<?xml version="1.0" ?>

Rikh tarafından işaret XML başlığına ek olarak, responseXML için text / xml doğru doldurulması gibi Content-Type başlığı ilan gerekebilir.

İşte benim php bulunuyor:

<?php

//turn on error reporting
ini_set('display_errors', 'On');
error_reporting(E_ALL | E_STRICT);
header('Content-Type: text/xml');

//pull variables
//need to do some error checking here
$username = ($_GET['username']);

//connect with database
$con = mysql_connect("localhost","***","");
if(!$con){
  die('Could not connect: ' . mysql_error());
}

mysql_select_db("musicneverstopped", $con);
//end connecting to database

//////////////////////////////////////////

//begin processing results
$result = mysql_query("SELECT * FROM user_fav_songs WHERE username = '$username'");

//error check
if(!$result){
  die(mysql_error());
}

//check if any results were returned
if(mysql_num_rows($result) > 0){

  //if so set up the xml
  $dom = new DOMDocument();
  $response = $dom->createElement('response');
  $dom->appendChild($response);

  while($row = mysql_fetch_array($result)){

    //create song node    
    $song = $dom->createElement('song');
    $idText = $dom->createTextNode($row['unique_song_id']);
    $song->appendChild($idText);
    $response->appendChild($song);
  }//end while

  //save and echo xml
  $xmlString = $dom->saveXML(); 
  echo $xmlString;
}//end if

//////////////////////////////////////////

//close database connection
mysql_close($con);//close mysql connection


?>

Bu doğru görünüyor mu?