简介在本文中,我们将引导您完成向网页添加文件上传功能的过程。我们将向您展示如何创建带有文件输入字段的 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网页中添加文件上传功能?的详细内容。