热搜词
发表于 2021-11-8 15:41:18 | 显示全部楼层 |阅读模式
实现功能:
上传时需填写所在单位,姓名和手机号,上传文件类型指定为zip或rar压缩格式文件,文件上传后,重命名为“单位名称+姓名+手机号+原文件名”的新文件。

前端html代码:
表单中  enctype="multipart/form-data" 的意思是设置表单的MIME编码。默认情况,这个编码格式是application/x-www-form-urlencoded,不能用于文件上传,只有使用了multipart/form-data,才能完整的传递文件数据。
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3.     <head>
  4.         <meta charset="UTF-8">
  5.         <title>文件上报系统</title>
  6.     </head>
  7.     <body>
  8. <h1>上传文件</h1>
  9. <form action="upload.php" method="post" enctype="multipart/form-data"  id="myform" name="myform" >
  10.         <h3 style="color: red">文件格式必须为ZIP或RAR压缩文件,且文件大小不要超过500MB。</h3><hr>
  11.         学校:
  12.                 <select name="school"id="school">
  13. <option value="0">请选择您所在学校!</option>
  14. <optgroup label="乡镇学校"></optgroup>
  15. <option value="其它">其它学校(园)</option>

  16.       </select>
  17.                 <br>
  18.         姓名:<input type="text" name="username" placeholder="输入文件上报者的姓名!" ><br>
  19.                 手机:<input type="text" name="mobile" placeholder="输入文件上报者的手机号!"><br>
  20.         <input type="hidden" name="MAX_FILE_SIZE" value="524288000" />
  21.         <input type="file" name="upfile" id="upfile" onchange="check()" size= "25" maxlength="100"><br><br>
  22.         <input type="submit" onclick="return validate()" value="提交"> <input type="button" onClick="history.back(-1)"  value="取消">
  23. </form>
  24. <script language="JavaScript" type="text/javascript">
  25.   function check()
  26.     {
  27. var aa=document.getElementById("upfile").value.toLowerCase().split('.');    //以“.”分隔上传文件字符串
  28.    // var aa=document.myform.upfile.value.toLowerCase().split('.');        //以“.”分隔上传文件字符串
  29.       
  30.     if(document.myform.upfile.value=="")
  31.     {
  32.                 alert('上传文件不能为空!');
  33.             return false;
  34.         } else {
  35.             if(aa[aa.length - 1] == 'zip' || aa[aa.length - 1] == 'rar' || aa[aa.length - 1] == 'pdf' || aa[aa.length - 1] == 'docx' || aa[aa.length - 1] == 'xlsx') //判断文件格式
  36.             {
  37.                 var fileSize = document.gemobileementById("upfile").files[0].size;
  38.                // alert("文件大小:" + fileSize /1024 + "KB")
  39.                 if(fileSize < 1024 * 1024 * 500)
  40.                  //   alert("文件大小在500M以内,为:" + fileSize / (1024 * 1024) + "MB");
  41.                 return true;
  42.             } else {
  43.                 alert('请选择格式为*.zip、*.rar、*.pdf、*.docx、*.xlsx 的文件');
  44.                 return false;
  45.             }
  46.         }
  47.     }
  48. </script>

  49. <script type="text/javascript">
  50. function validate(){

  51. var slt=document.getElementById("school");
  52. if(slt.value=="0"){
  53. alert("请选择所在学校!");
  54. return false;
  55. }

  56. var username=myform.username.value;
  57. var mobile=myform.mobile.value;
  58. if(username.length==0){
  59. alert('用户名不能为空!');
  60. myform.username.focus();
  61. return false;
  62. }
  63. var reg=/^[\u0391-\uFFE5]+$/;
  64. if(username!=""&&!reg.test(username)){
  65. alert('用户名必须输入中文!');
  66. return false;
  67. }
  68. if(mobile.length==0){
  69. alert("手机号码不能为空!");
  70. myform.mobile.focus();
  71. return false;
  72. }
  73. else if(mobile.length!=11){
  74. alert("请输入有效位数的手机号码!")
  75. myform.mobile.focus();
  76. return false;
  77. }
  78. var myreg = /^(((13[0-9]{1})|(15[0-9]{1})|(18[0-9]{1}))+\d{8})$/;
  79. if(!myreg.test(mobile)) {
  80. alert("请输入正确格式的手机号码!");
  81. return false;
  82. }

  83. if(username.length==0){
  84. alert('用户名不能为空!');
  85. myform.username.focus();
  86. return false;
  87. }

  88. if(document.myform.upfile.value=="")
  89. {
  90. alert('上传文件不能为空!');
  91. return false;
  92. }
  93. return true;
  94. }
  95. </script>

  96.     </body>
  97. </html>
复制代码


后端php文件代码:

  1. <?php
  2. $school = $_POST['school'];
  3. $username = $_POST['username'];
  4. $mobile = $_POST['mobile'];
  5.         //拿到文件
  6.         $file=$_FILES['upfile'];
  7.         //临时文件存放路径
  8.     $fileTmp = $file['tmp_name'];
  9.         //原文件名(带后缀)
  10.     $fileName = $file['name'];
  11.         //新文件名(带后缀)
  12.         $newfileName = date('Ymd'). "-" . $school . "-" . $username . "-" . $mobile . "-" . $_FILES["upfile"]["name"];  //上传文件路径和新文件名
  13.         //存储路径和新文件名(带后缀)
  14.         $pathfileName = "./uploads/" . $newfileName;  //上传文件路径和新文件名
  15.     //文件文件类型
  16.     $fileType = $file['type'];
  17.     //文件大小(字节)
  18.     $fileSize = $file['size'];
  19.     //错误,输出0,表示文件提交成功
  20.     $fileError = $file['error'];
  21.     if($fileError==0){
  22.             //判断文件类型
  23.             $file_type=['application/octet-stream','application/zip'];
  24.             if(!in_array($fileType,$file_type)){
  25.                 echo '文件上传类型错误,请上传zip或rar压缩格式文件!';
  26.                     die;
  27.             }
  28.   else
  29.   {
  30.     // 判断当期目录下的 upload 目录是否存在该文件
  31.     if (file_exists($pathfileName))
  32.     {
  33.       echo "错误:该文件已存在!". "<br>";
  34.            echo "<input type='button' onClick='history.back(-1)'  value='返回'>";
  35.     }
  36.     else
  37.     {
  38.      //移动临时文件到上传的文件存放的位置(核心代码)
  39.      //括号里:1.临时文件的路径, 2.存放的路径
  40.       move_uploaded_file($fileTmp,$pathfileName);
  41.      echo "恭喜您,文件上传成功!". "<br><br>";
  42.          echo "文件名: " . $fileName . "<br>";
  43.      // echo "文件类型: " . $fileType . "<br>";
  44.      echo "文件大小: " . round($fileSize / 1024,2) . " kB<br>";
  45.          echo "上传日期: " . date('Y-m-d') . " <br><br>";
  46.      //  echo "文件临时存储的位置: " . $fileTmp . "<br>";  
  47.         echo "所在学校:". $school. "<br>";
  48.         echo "您的姓名:". $username. "<br>";
  49.         echo "您的手机:". $mobile. "<br><br>";
  50.         echo "<input type='button' onClick='history.back(-1)'  value='返回'>";
  51.                 }
  52.   }
  53. }
  54. else
  55. {
  56.   echo "错误:上传失败" . "<br>";

  57.         switch ($fileError) {

  58.             case 1:

  59.                 echo '上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值';

  60.                 break;

  61.             case 2:

  62.                 echo '上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值';

  63.                 break;

  64.             case 3:

  65.                 echo '文件只有部分被上传';

  66.                 break;

  67.             case 4:

  68.                 echo '没有文件被上传';

  69.                 break;

  70.             case 6:

  71.                 echo '找不到临时文件夹';

  72.                 break;

  73.             case 7:

  74.                 echo '文件写入失败';

  75.                 break;

  76. }
  77.   echo "<br>";
  78.   echo "<input type='button' onClick='history.back(-1)'  value='返回'>";

  79. }





  80. ?>
复制代码



全部评论0
回复
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|Archiver|手机版|小黑屋|管理员之家 ( 苏ICP备2023053177号-2 )

GMT+8, 2024-12-27 19:29 , Processed in 0.166565 second(s), 22 queries .

Powered by Discuz! X3.5

Cpoyright © 2001-2024 Discuz! Team