PHPコーディングを行ってから長い時間が経ったので、本当に振り出しに戻りました。本当に明らかな/些細なことを見逃している場合は、事前に謝罪してください。
データを処理して送信し、XML ファイルの特定のセクションにコードを追加するフォームを作成しようとしています。
これは私が持っているものです
<? $title = $_POST['title'] ;
$author = $_POST['author'];
$filesize = $_POST['filesize'];
$pubdate = $_POST['pubdate'];
$duration = $_POST['duration'];
$summary = $_POST['summary'];
$key = '<itunes:category text="Business"></itunes:category>';
$newline = '<item>
<title>$title</title>
<link>http://example.com/CS/podcast/<? php echo($target_path);?></link>
<itunes:author>$author</itunes:author>
<itunes:summary><?php echo($summary); ?></itunes:summary>
<enclosure url="http://example.com/CS/$targetpath" length="$filesize" type="audio/mpeg"/>
<guid>http://www.example.com/CS/podcast/<? php echo($target_path);?></guid>
<pubDate><?php echo($pubdate);?></pubDate>
<itunes:duration><?php echo($duration);?></itunes:duration>
<itunes:keywords>My Podcast</itunes:keywords>
<category>Podcasts</category>
<itunes:explicit>no</itunes:explicit>
</item>';
//copy file to prevent double entry
$file = "list.xml";
$newfile = "listtemp.xml";
copy($file, $newfile) or exit("failed to copy $file");
//load file into $lines array
$fc = fopen ($file, "r");
while (!feof ($fc))
{
$buffer = fgets($fc, 4096);
$lines[] = $buffer;}
fclose ($fc);
//open same file and use "w" to clear file
$f=fopen($newfile,"w") or die("couldn't open $file");
/* uncomment to debug
print_r($lines);
print "<br>\n";
*/
//loop through array using foreach
foreach($lines as $line){
fwrite($f,$line); //place $line back in file
if (strstr($line,$key)){ //look for $key in each line
fwrite($f,$newline."\n");
} //place $line back in file }
fclose($f);
copy($newfile, $file) or exit("failed to copy $newfile");
echo "done";
echo "$newline";?>
私が抱えていると思われる問題は、コードを適切な場所に完全に追加することですが、入力されたタイトルの代わりに $title を表示することです。
問題は、別の変数内に変数を含めることができないことだと思います。誰かがコードをフォームに入力するだけで危険になる可能性があるためです。これを回避する方法はありますか? これは内部使用のみに限定されるため、厳密なセキュリティは必要ありません。
見つかった
http://uk3.php.net/manual/en/function.eval.php しかし、うまく活用できていません。
ありがとうございました