私の目標は、フォームの送信ボタンをクリックすると、添付ファイルをフォームからサーバーにアップロードし、その進行状況バーを表示してからフォームを送信することです(つまり、メッセージをメールで送信します)。
アップロードフォーム.php:
<form action="email_message.php" method="post" enctype="multipart/form-data" name="fileform" id="fileform">
<input type="hidden" name="MAX_FILE_SIZE" value="50000000"/>
<input type="hidden" name="<?php echo ini_get("session.upload_progress.name"); ?>" value="uploads"/>
<label for="userfile1">Upload a file:</label>
<input type="file" name="userfile1" id="userfile1" class="userfile"/>
<input id="submit_btn" type="submit" value="Send Message"/>
</form>
同じページで次のコードを実行して、フォームが実行されないようにし、フォームからすべてのファイルをアップロードするリクエストを送信するのを防ぎます。
$(document).ready(function(){
$("#fileform").submit(function(e){
e.preventDefault();
var self = this;
var formData = new FormData(document.getElementById("fileform"));
var upload_req = $.ajax({
url: "./upload_multiple_files.php",
type: "POST",
data: formData,
processData: false,
contentType: false
});
upload_req.done(function(data){
alert("Uploading complete!");
});
});
});
upload_multiple_files.php:
<?php
session_start();
foreach ($_FILES as $k => $v){
// code to deal with file errors
if (is_uploaded_file($v['tmp_name'])){
// code to rename file
echo "<p>The file was successfully uploaded.</p>";
}else{
echo "<p>The file was not uploaded.</p>";
}
}
?>
これはすべて機能します。ファイルはすべてサーバーにアップロードされます。
私が抱えている問題は、PHP Upload Session Progress ( http://php.net/manual/en/session.upload-progress.php ) を統合することです。
session.upload_progress.name
ファイルのアップロード情報を取得するには、配列を使用する必要があることはわかって$_POST
いますが、どこに配置すればよいかわかりません。フォームページにアップロードの進行状況を定期的に表示する間隔で ajax 呼び出しを作成したいと考えています。しかし、新しいページを作成すると、セッション情報が空になります。私が試したページの例を次に示します。
get_progress.php:
<?php
session_start();
// $key is a combination of session.upload_progress.prefix and session.upload_progress.name
$results = array("content_length" => $_SESSION[$key]['content_length'],
"bytes_processed" => $_SESSION[$key]['bytes_processed']
);
echo json_encode($results);
?>
upload_form.php
とのセッション ID を確認しましたget_progress.php
が、それらは同じです。
$_SESSION
が空である理由はget_progress.php
何ですか? 簡単なことを見逃したと思いますが、わかりません。