PHPスクリプトを使用してhtmlでファイルをアップロードしようとしています。
<html>
<body>
<form id='importPfForm' enctype="multipart/form-data" action="http://localhost/js/upload.php" method="post">
<input type="hidden" name="MAX_FILE_SIZE" value="1000000" />
Choose a file to upload: <input name="uploaded_file" type="file" />
<input type="submit" value="Upload" />
</form>
</body>
</html>
「upload.php」には次のコードが含まれています。
<?php
$upload_key = 'uploaded_file';
if (isset($_FILES[$upload_key])) {
try {
$error = $_FILES[$upload_key]['error'];
switch ($error) {
case UPLOAD_ERR_INI_SIZE:
throw new Exception('Exceeded upload_max_filesize');
case UPLOAD_ERR_FORM_SIZE:
throw new Exception('Exceeded MAX_FILE_SIZE');
case UPLOAD_ERR_PARTIAL:
throw new Exception('Incomplete file uploaded');
case UPLOAD_ERR_NO_FILE:
throw new Exception('No file uploaded');
case UPLOAD_ERR_NO_TMP_DIR:
throw new Exception('No tmp directory');
case UPLOAD_ERR_CANT_WRITE:
throw new Exception('Can\'t write data');
case UPLOAD_ERR_EXTENSION:
throw new Exception('Extension error');
}
$finfo = new finfo(FILEINFO_MIME);
$name = $_FILES[$upload_key]['name'];
$tmp_name = $_FILES[$upload_key]['tmp_name'];
$size = $_FILES[$upload_key]['size'];
if ($size > 350000)
throw new Exception('Exceeded 350KB limit');
if (!is_uploaded_file($tmp_name))
throw new Exception('Not an uploaded file');
$type = $finfo->file($tmp_name);
if ($type === false)
throw new Exception('Failed to get MimeType');
if ($type !== 'text/plain; charset=us-ascii')
throw new Exception('Only csv available');
$new_name = dirname(__FILE__).'/upload/'.$name;
echo $new_name;
if (is_file($new_name))
throw new Exception("The file {$new_name} already exists");
if (!move_uploaded_file($tmp_name,$new_name))
throw new Exception('Failed to move uploaded file');
echo "File successfully uploaded as {$new_name}";
} catch (Exception $e) {
echo 'Error: '.$e->getMessage();
}
}
?>
ただし、この方法では新しい Web ページが開きます。Web ページを離れずに関数を実行したいのですが $new_name
、html ページで変数を使用する必要があります。HTML ページで実行する必要がある変更は何ですか? これは、ある種の ajax リクエストを介して機能すると確信しています。しかし、私は私が何について話しているのか分かりません。私は ajax や JavaScript にはあまり詳しくありませんが、これは私が頻繁に使用する関数であり、現在および将来必要なときに実装できるように、そのしくみを学びたいと考えています。