0

同様のトピックに関するさまざまな投稿がここにあります。残念ながら、これらは役に立ちませんでした。

データが見つかったと仮定して、そこから適切なフォーム フィールドに入力する XML ファイルを作成する php ファイルに ajax 呼び出しを行います。

次のように戻りデータを XML に指定すると、成功せず、「XML ファイルを取得できませんでした」というアラートが表示されます。

function check_Address(){

alert("username=" + $("#username").attr("value"));

$.ajax({
    type: "POST",
    url: "admin_Check_Address.php",
    data: "username=" + $("#username").attr("value"),
    dataType: "xml",                
    success: function(return_Data){
        set_Address(return_Data);
    },
    error: function(return_Data){
        alert("Could not retrieve XML file.");
    }
});  // end ajax call
}

ただし、データ型を削除すると、関数 set_Address が実行され、return_Data の tagNames が検出され、フィールドが正しく設定されます。すなわち

function check_Address(){

alert("username=" + $("#username").attr("value"));

$.ajax({
    type: "POST",
    url: "admin_Check_Address.php",
    data: "username=" + $("#username").attr("value"),
    success: function(return_Data){
        set_Address(return_Data);
    },
    error: function(return_Data){
        alert("Could not retrieve XML file.");
    }
});  // end ajax call
}

これがphpです:

<?php 

/*
 * Accept username from Ajax
 * Get appropriate key
 * Check for pre existing address(es)
 */

if(isset($_POST["username"])){

    // retrieve user key

    $sql  = "SELECT * FROM User ";
    $sql .= "WHERE username = ";
    $sql .= "'";
    $sql .= $_POST['username']; 
    $sql .= "'";
    $sql .= " LIMIT 1;";
    $user = User::find_By_Sql($sql);
    $user_Key = $user[0]->get_User_Key();

    // check for an existing address or addresses

    $sql  = "SELECT * FROM Address ";
    $sql .= "WHERE user_Key = ";
    $sql .= "'";
    $sql .= $user_Key;  
    $sql .= "';";
    $addresses = Address::find_By_Sql($sql);

    // how many addresses found
    // if none nothing to do except set focus on address 1
    // if 1 address returned check active and return xml to complete fields
    // if >1 return xml to create list for user to select from

    echo "addr ct:" . count($addresses);

    if (count($addresses) == 1){
        construct_XML($addresses[0]);
    }
} else {
    echo "error nothing passed";
}


function construct_XML($address){

    echo ("start xml");

    $xml_String  = "<?xml vesrion=\"1.0\"?>";
    $xml_String .= "<addresses>";
    $xml_String .= "<address>";
    $xml_String .= "<username>";
    $xml_String .= $_POST['username'];
    $xml_String .= "</username>";
    $xml_String .= "<address1>";
    $xml_String .= $address->address_1;
    $xml_String .= "</address1>";
    $xml_String .= "<address2>";
    $xml_String .= $address->address_2;
    $xml_String .= "</address2>";
    $xml_String .= "<city>";
    $xml_String .= $address->city;
    $xml_String .= "</city>";
    $xml_String .= "<county>";
    $xml_String .= $address->county;
    $xml_String .= "</county>";
    $xml_String .= "<country>";
    $xml_String .= $address->country;
    $xml_String .= "</country>";
    $xml_String .= "<post_Code>";
    $xml_String .= $address->post_Code;
    $xml_String .= "</post_Code>";
    $xml_String .= "</address>";
    $xml_String .= "</addresses>";

    echo $xml_String;

}

?>

XML を読み取る set address 関数は次のとおりです。

function set_Address(return_Data){

$("#address_1").attr("value", $("address1", return_Data).text());
$("#address_2").attr("value", $("address2", return_Data).text());
$("#city").attr("value", $("city", return_Data).text());
$("#county").attr("value", $("county", return_Data).text());
$("#country").attr("value", $("country", return_Data).text());          
$("#code").attr("value", $("post_Code", return_Data).text());
}

文字列をエコーするのではなく、file.xml を返す必要があると考えていますが、これを行う方法がわかりません。

私が間違っているアイデアはありますか?単純に dataType を省略でき、すべて正常に動作しますが、これが XML として認識されない理由を知りたいので、次回に理解します。

どうもありがとう。

回答ありがとうございます。はい、元の投稿に 2 つの間違いがあり、不要な 2 行がエコーされていました。

これで、ajax がこれを XML として受信できるようにするには、文字列の前にヘッダーを含める必要があることがわかりました。

header ("Content-Type:text/xml");

ただし、Jquery で PHP から返されたデータを正しく解析できませんでした。

xml 解析エラー 要素が見つからない場所 moz-nullprincipal

これを解決できませんでした。したがって、私は ajax を更新して、ある呼び出しを別の呼び出しにネストして、php が XML を返すようにしました。これが適切かどうかはわかりませんが、機能します:.....

ここにphpがあります

<?php require_once("../../_includes/initialize.php"); ?>


<?php 

/*
 * Accept username from Ajax
 * Get appropriate key
 * Check for pre existing address(es)
 */

$tmpuser = "john@hotmail.co.uk";

if(isset($_POST["username"])){

    // retrieve user key

    $sql  = "SELECT * FROM User ";
    $sql .= "WHERE username = ";
    $sql .= "'";
    $sql .= $_POST['username']; 
    $sql .= "'";
    $sql .= " LIMIT 1;";
    $user = User::find_By_Sql($sql);
    $user_Key = $user[0]->get_User_Key();

    // check for an existing address or addresses

    $sql  = "SELECT * FROM Address ";
    $sql .= "WHERE user_Key = ";
    $sql .= "'";
    $sql .= $user_Key;  
    $sql .= "';";
    $addresses = Address::find_By_Sql($sql);

    // how many addresses found
    // if none nothing to do except set focus on address 1
    // if 1 address returned check active and return xml to complete fields
    // if >1 return xml to create list for user to select from

    if (count($addresses) == 1){
        construct_XML($addresses[0]);
    }
} else {
    //"error nothing passed";
}


function construct_XML($address){

// initialize xml object

$xml_Data = simplexml_load_string("<?xml version='1.0'?>\n<addresses></addresses>");

$address_Detail = $xml_Data->addChild("address");
$address_Detail->addChild("username", $_POST['username']);
$address_Detail->addChild("address1", $address->address_1);
$address_Detail->addChild("address2", $address->address_2);
$address_Detail->addChild("city", $address->city);
$address_Detail->addChild("county", $address->county);
$address_Detail->addChild("country", $address->country);
$address_Detail->addChild("post_Code", $address->post_Code);

$fp = fopen("addresses.xml","wb");
fwrite($fp,$xml_Data->asXML());
fclose($fp);

}

?>

修正された Ajax 呼び出しは次のとおりです。

function check_Address(){

$.ajax({
    type: "POST",
    url: "admin_Check_Address.php",
    data: "username=" + $("#username").attr("value"),
    success: function(return_Data){
            $.ajax({
            type: "POST",
            url: "addresses.xml",
            dataType: "xml",
            success: function(xml_Data){
                set_Address(xml_Data);
            },
            error: function(){
                alert("Could not retrieve XML file.");
            }
        });  // end innerajax call  
    },
    error: function(){
        alert("Could not retrieve XML file.");
    }
});  // end ajax call   
}

set_Address 調整関数

function set_Address(xml_Data){

$("#address_1").attr("value", $("address1", xml_Data).text());
$("#address_2").attr("value", $("address2", xml_Data).text());
$("#city").attr("value", $("city", xml_Data).text());
$("#county").attr("value", $("county", xml_Data).text());
$("#country").attr("value", $("country", xml_Data).text());         
$("#code").attr("value", $("post_Code", xml_Data).text());

}

そのため、100% ではありませんが、1 回のヒットで ajax 呼び出しを実行できるようにしたいと考えています。したがって、これ以上のアドバイスは大歓迎です。

4

2 に答える 2

3

PHPで適切なヘッダーを設定する必要があります。

header ("Content-Type:text/xml");

また、echo ("start xml"); xml の出力を開始する前に、問題が発生する可能性があります。

于 2012-07-16T09:27:09.783 に答える
1

おそらく、サーバーからの戻り応答には、XML とは異なるヘッダーが含まれています (firebug で確認できます)。

したがって、実際に送信するのは、html マークアップを含む xml です (ヘッダーにそう記載されているため)。

返された応答が ajax 呼び出しで XML であると明示的に言うと、解析できなくなります。

何も設定しない場合、HTML を読み取ることができますが、DOM 要素のようになります。

ヘッダーを正しく設定すると、おそらく修正されます

header ("Content-Type:text/xml"); 
于 2012-07-16T09:27:20.033 に答える