我使用這種形式的文件上傳表單(作爲一個更大的PHP腳本的一部分,$ PK在實際的東西消毒):使用表單變量與文件上傳腳本
<?php
if (isset($_GET["pk"]))
{ $pk = $_GET["pk"];}
echo '<form action="up.php" method="post"
enctype="multipart/form-data">
<label for="file">Filename:</label>
<input type="file" name="file" id="file" />
<input type="hidden" name="pk" value="$pk">
<br />
<input type="submit" name="submit" value="Submit" />
</form>';
?>
我使用以下(非常修剪)的代碼來處理上傳。任何語法錯誤都是我使用的tabifier的結果。
<?php
if (isset($_GET["pk"])) {
$pk = $_GET["pk"];
}
$con = mysqli_connect("localhost","x","x", "x");
echo "Upload: " . $_FILES["file"]["name"] . "<br />";
echo "Type: " . $_FILES["file"]["type"] . "<br />";
echo "Size: " . ($_FILES["file"]["size"]/1024) . " Kb<br />";
echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br />";
move_uploaded_file($_FILES["file"]["tmp_name"],
"./" . $_FILES["file"]["name"]);
echo "Stored in: " . "./" . $_FILES["file"]["name"];
$fileQuery = "INSERT INTO FILES VALUES (?, ?)";
if ($fileInsert = $con->prepare($fileQuery)) {
$fileInsert->bind_param("ss", $pk, $_FILES["file"]["name"]);
$fileInsert->execute();
$fileInsert->close();
} else {
print_r($con->error);
}
?>
我想知道的是,如何訪問$ pk。它是否已經通過表單傳遞給處理代碼?
所以在處理代碼,我應該有(isset($ _ POST [ 「PK」])){ $ PK = $ _POST [ 「PK」]; ? – 2009-04-30 13:45:04
yep____________ – SilentGhost 2009-04-30 13:49:19