0

MYSQL データを XML (CSS を使用してスタイル設定) に変換する PHP スクリプトがあります。ページに HTML テキストとリンクが表示されるように、このページに HTML を少し追加する必要があります。次のようなエラーを返さずに、それらをphpスクリプトに追加するにはどうすればよいですか。

このページには次のエラーが含まれています: 行 44 の 1 列目のエラー: ドキュメントの末尾にある余分なコンテンツ 以下は、最初のエラーまでのページのレンダリングです。

できるだけ説明的で明確であることができれば、それは非常に役立ちます. ありがとう

phpスクリプトは次のとおりです。

<?php 

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

$host = "###"; 
$user = "###"; 
$pass = "###"; 
$database = "###"; 
$xslt_file = "/xmlstyle.css"; 
$linkID = mysql_connect($host, $user, $pass) or die("Could not connect to host."); 
mysql_select_db($database, $linkID) or die("Could not find database."); 

$query = "SELECT * FROM users WHERE Username = 'Username4';";


$resultID = mysql_query($query, $linkID) or die("Data not found."); 

$xml_output = "<?xml version=\"1.0\"?>\n"; 
//$xml_output .= "<?xml-stylesheet href=\"$xslt_file\" type=\"text/xsl\" ?
$xml_output .= "<?xml-stylesheet href=\"$xslt_file\" type=\"text/css\" ?>";

$xml_output .= "<Users>\n"; 

for($x = 0 ; $x < mysql_num_rows($resultID) ; $x++){ 
    $row = mysql_fetch_assoc($resultID); 
    $xml_output .= "\t<Person>\n"; 
    $xml_output .= "\t\t<Username>" . $row['username'] . "</Username>\n"; 
    $xml_output .= "\t\t<Firstname>" . $row['firstname'] . "</Firstname>\n"; 
    $xml_output .= "\t\t<Lastname>" . $row['lastname'] . "</Lastname>\n";
    $xml_output .= "\t\t<Title>" . $row['Title'] . "</Title>\n";
    $xml_output .= "\t\t<Description>" . $row['Description'] . "</Description>\n";  
    $xml_output .= "\t\t<Location>" . $row['Location'] . "</Location>\n";
    $xml_output .= "\t\t<Feeling>" . $row['Feeling'] . "</Feeling>\n";
        // Escaping illegal characters 
        $row['text'] = str_replace("&", "&", $row['text']); 
        $row['text'] = str_replace("<", "<", $row['text']); 
        $row['text'] = str_replace(">", "&gt;", $row['text']); 
        $row['text'] = str_replace("\"", "&quot;", $row['text']); 

    $xml_output .= "\t</Person>\n"; 
} 

$xml_output .= "</Users>"; 

echo $xml_output; 

?> 

表示したい HTMl のいくつかの例を次に示します。

<a href="http://www.w3schools.com">Visit W3Schools</a></br><hr noshade size="1" width="90%" align="center">
<a href="http://www.w3schools.com">Visit W3Schools</a></br><hr noshade size="1" width="90%" align="center">
<a href="http://www.w3schools.com">Visit W3Schools</a></br><hr noshade size="1" width="90%" align="center">
<a href="http://www.w3schools.com">Visit W3Schools</a></br>
4

2 に答える 2

1

XML ファイルに HTML を追加しようとする代わりに、XML ドキュメントを HTML ページに表示することを考えてみませんか。

于 2013-07-18T12:42:45.047 に答える
0

xml を外部ファイルに入れてから、データを表示したい php ページで、simplexml_load_file() を使用して xml コンテンツを出力できます。

<?php
    function outputxml(){
        $file = '/path/to/your/file.xml';
        $xml = simplexml_load_file($file);
        $xpath = $xml->xpath('USERS/PERSON');

        foreach($xpath as $person){
            echo '<p>'.$person->[Username].'</p>';
            echo '<p>'.$person->[Firstname].'</p>';
            echo '<p>'.$person->[Lastname].'</p>';
            echo '<p>'.$person->[Title].'</p>';
            echo '<p>'.$person->[Description].'</p>';
            echo '<p>'.$person->[Location].'</p>';
            echo '<p>'.$person->[Feeling].'</p>';
        }
    }
    outputxml();
?>
<a href="http://www.w3schools.com">Visit W3Schools</a><br /><hr class="noshade_center" />
<a href="http://www.w3schools.com">Visit W3Schools</a><br /><hr class="noshade_center" />
<a href="http://www.w3schools.com">Visit W3Schools</a><br /><hr class="noshade_center" />
<a href="http://www.w3schools.com">Visit W3Schools</a><br />

ご存知のように、スラッシュは break タグと hr タグの「br」の後にあり、hr タグは css でスタイルする必要があります。

于 2016-07-06T21:15:30.040 に答える