如何在HTML网页中添加文件上传功能?

简介

在本文中,我们将引导您完成向网页添加文件上传功能的过程。我们将向您展示如何创建带有文件输入字段的 HTML 表单,以及如何创建处理文件上传过程的脚本。

方法

我们可以使用以下两种方法在 HTML 网页中添加文件上传功能 –

  • 使用带有文件输入字段的基本 HTML 表单

  • 使用 jQuery 和 ajax

现在让我们详细讨论它们。

方法 1:使用带有文件输入字段的基本 HTML 表单

此方法涉及创建一个简单的 HTML 表单,其中包含一个文件输入字段,允许用户选择要上传的文件。然后,该表单被发送到处理文件实际保存的服务器端脚本。

第 1 步 – 创建一个名为 index.html 的文件。

步骤 2 – 创建一个带有文件输入字段的 HTML 表单。

示例

让我们通过示例更好地理解这一点。

示例

让我们通过示例更好地理解这一点。 >

<!DOCTYPE html>
<html>
<head>
   <title>File Upload</title>
</head>
<body>
   <h1>Welcome to Tutorials Point</h1>
   <form action="upload.php" method="post" enctype="multipart/form-data">
      <input type="file" name="uploadedFile">
      <input type="submit" value="Upload">
   </form>
</body>
</html>

这将创建一个 HTML 表单,其中包含一个文件输入字段,允许用户选择要上传的文件,以及一个用于发送表单的提交按钮。 action 属性设置为“upload.php”,这是处理文件上传的服务器端脚本。 enctype 属性设置为“multipart/form-data”,这是文件上传所必需的。

第 3 步 – 创建服务器端 PHP 脚本 (action.php) 来处理文件上传。

<?php
   if(isset($_FILES['uploadedFile'])){
      $errors= array();
      $file_name = $_FILES['uploadedFile']['name'];
      $file_size = $_FILES['uploadedFile']['size'];
      $file_tmp = $_FILES['uploadedFile']['tmp_name'];
      $file_type = $_FILES['uploadedFile']['type'];
      $file_ext=strtolower(end(explode('.',$_FILES['uploadedFile']['name'])));
      $extensions= array("jpeg","jpg","png");

      if(in_array($file_ext,$extensions)=== false){
         $errors[]="extension not allowed, please choose a JPEG or PNG file.";
      }

      if($file_size > 2097152) {
         $errors[]='File size must be excately 2 MB';
      }

      if(empty($errors)==true) {
         move_uploaded_file($file_tmp,"upload/".$file_name);
         echo "Success";
      }else{
         print_r($errors);
      }
   }
?>

此脚本首先使用 isset 函数和 $_FILES 超全局变量检查文件输入字段是否包含文件。然后,该脚本使用 in_array 函数和预定义的允许文件扩展名列表检查文件大小和文件扩展名。如果文件有效,则使用 move_uploaded_file 函数将其移动到服务器上的“upload”目录。如果文件无效,则会显示错误消息。

方法 2:使用 jQuery 和 ajax

此方法是处理文件上传的更高级方法,允许您无需刷新页面即可处理文件上传过程。

第 1 步 – 创建一个名为index.html的文件

第 2 步 – 在该文件中包含 jQuery 和 jQuery 表单插件 –

示例

让我们通过示例更好地理解这一点。

>

<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<script src="https://malsup.github.io/jquery.form.js"></script>

此步骤涉及在 HTML 文档中包含 jQuery 和 jQuery Form Plugin 库。这些库将允许您使用 ajaxForm 方法通过 JavaScript 处理文件上传过程。

第 3 步 − 创建带有文件输入字段的 HTML 表单 –

<form id="fileUploadForm" action="upload.php" method="post" enctype="multipart/form-data">
   <input type="file" name="uploadedFile">
   <input type="submit" value="Upload">
</form>

此步骤与方法 1 的步骤 1 类似。您创建一个包含文件输入字段和提交按钮的 HTML 表单,并将操作属性设置为指向将处理文件上传的服务器端脚本,并将 enctype 属性设置为“multipart/form-data”,因为这是文件上传所必需的。

第 4 步 – 使用 jQuery 处理文件上传 –

$(document).ready(function(){
   $('#fileUploadForm').ajaxForm({
      beforeSubmit: function(){
         
         // do validation here
         var fileInput = document.getElementById('fileInput');
         var file = fileInput.files[0];
         var maxFileSize = 2097152; // 2 MB
         var validFileExtensions = ["jpg", "jpeg", "png"];
         var extension = file.name.split('.').pop().toLowerCase();
         if(file.size > maxFileSize) {
            alert("File size must be exactly 2 MB.");
            return false;
         }
         if(validFileExtensions.indexOf(extension) === -1) {
            alert("Invalid file type. Only JPEG and PNG files are allowed.");
            return false;
         }
      },
      success: function(response){
         
         // handle response
         var jsonResponse = JSON.parse(response);
         if(jsonResponse.status === "success"){
            alert("File upload successful!");
         }else{
            alert("File upload failed. Please try again.");
         }
      },
      error: function(response){
         
         // handle errors
         alert("There was an error while uploading the file. Please try again later.");
      }
   });
});

此步骤涉及使用 jQuery 来处理文件上传过程。 ajaxForm 方法用于通过 JavaScript 提交表单,beforeSubmit、success 和 error 函数用于处理文件上传过程的各个阶段。

beforeSubmit函数用于在上传前验证文件,success函数用于处理文件上传后服务器的响应。 error 函数用于处理文件上传过程中发生的任何错误。

第 5 步 – 此处包含 index.html 文件的 jQuery 代码的完整 HTML –

示例

<!DOCTYPE html>
<html>
<head>
   <script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
   <script src="https://malsup.github.io/jquery.form.js"></script>
</head>
<body>
   <h1>Greetings from Tutorials Point!</h1>
   <form id="fileUploadForm" action="upload.php" method="post" enctype="multipart/form-data">
      <input type="file" name="uploadedFile">
      <input type="submit" value="Upload">
   </form>
   <script>
      $(document).ready(function(){
         $('#fileUploadForm').ajaxForm({
            beforeSubmit: function(){
               
               // do validation here
               var fileInput = document.getElementById('fileInput');
               var file = fileInput.files[0];
               var maxFileSize = 2097152; // 2 MB
               var validFileExtensions = ["jpg", "jpeg", "png"];
               var extension = file.name.split('.').pop().toLowerCase();
               if(file.size > maxFileSize) {
                  alert("File size must be exactly 2 MB.");
                  return false;
               }
               if(validFileExtensions.indexOf(extension) === -1) {
                  alert("Invalid file type. Only JPEG and PNG files are allowed.");
                  return false;
               }
            },
            success: function(response){
            
               // handle response
               var jsonResponse = JSON.parse(response);
               if(jsonResponse.status === "success"){
                  alert("File upload successful!");
               }else{
                  alert("File upload failed. Please try again.");
               }
            },
            error: function(response){
               
               // handle errors
               alert("There was an error while uploading the file. Please try again later.");
            }
         });
      });
   </script>
</body>
</html>

第 6 步 – 创建 PHP 服务器端脚本 (upload.php) 来处理文件上传 –

<?php
   if(isset($_FILES['uploadedFile'])){
      $errors= array();
      $file_name = $_FILES['uploadedFile']['name'];
      $file_size = $_FILES['uploadedFile']['size'];
      $file_tmp = $_FILES['uploadedFile']['tmp_name'];
      $file_type = $_FILES['uploadedFile']['type'];
      $file_ext=strtolower(end(explode('.',$_FILES['uploadedFile']['name'])));

      $extensions= array("jpeg","jpg","png");

      if(in_array($file_ext,$extensions)=== false){
         $errors[]="extension not allowed, please choose a JPEG or PNG file.";
      }

      if($file_size > 2097152) {
         $errors[]='File size must be excately 2 MB';
      }

      if(empty($errors)==true) {
         move_uploaded_file($file_tmp,"upload/".$file_name);
         echo "Success";
      }else{
         print_r($errors);
      }
   }
?>

该脚本首先使用 isset 函数和 $_FILES 超全局变量检查文件输入字段是否包含文件。然后,该脚本使用 in_array 函数和预定义的允许文件扩展名列表检查文件大小和文件扩展名。如果文件有效,则使用 move_uploaded_file 将其移动到服务器上的“upload”目录。

结论

在本文中,我们讨论了两种在 HTML 网页中添加文件上传功能的方法。第一种方法是使用带有文件输入字段的基本 HTML 表单,然后将该表单发送到处理文件实际保存的服务器端脚本。第二种方法是使用 jQuery 和 ajax,这种方法允许您处理文件上传过程而无需刷新页面。

这两种方法都需要正确的验证、存储文件的正确方法、在服务器端具有正确的权限,以及出于安全原因清理文件名和扩展名的正确方法。

以上就是如何在HTML网页中添加文件上传功能?的详细内容,更多请关注双恒网络其它相关文章!

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!
8. 精力有限,不少源码未能详细测试(解密),不能分辨部分源码是病毒还是误报,所以没有进行任何修改,大家使用前请进行甄别
9.本站默认解压密码为:www.sudo1.com
本站提供的一切软件、教程和内容信息仅限用于学习和研究目的。
不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。
本站信息来自网络收集整理,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑或手机中彻底删除上述内容。
如果您喜欢该程序和内容,请支持正版,购买注册,得到更好的正版服务。
我们非常重视版权问题,如有侵权请邮件与我们联系处理。敬请谅解!

云资源网 » 如何在HTML网页中添加文件上传功能?

常见问题FAQ

免费下载或者VIP会员专享资源能否直接商用?
本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
提示下载完但解压或打开不了?
最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。 若排除这种情况,可在对应资源底部留言,或 联络我们.。
你们有qq群吗怎么加入?
当然有的,如果你是帝国cms、易优cms、和pbootcms系统的爱好者你可以加入我们的QQ千人交流群https://sudo1.com/page-qun.html。
  • 会员数(个)
  • 12275资源数(个)
  •        
  • 资源(G)
  •        
  • 今日下载
  • 1365稳定运行(天)

提供最优质的资源集合

立即查看 了解详情