黑帽联盟

 找回密码
 会员注册
查看: 1348|回复: 0
打印 上一主题 下一主题

[php] php利用iframe实现无刷新文件上传功能的代码

[复制链接]
yun 黑帽联盟官方人员 

920

主题

37

听众

1364

积分

超级版主

Rank: 8Rank: 8

  • TA的每日心情
    奋斗
    2019-10-18 11:20
  • 签到天数: 678 天

    [LV.9]以坛为家II

    上传原理很简单就是利用表单的打开方式为iframe的id名,这样就可以在当前页面的iframe打来了,实现文件上传,再利用js返回上传结果,下面直接上代码:
    1. <html>
    2.   <head>
    3.   <title>无刷新上传文件</title>
    4.   <meta Content-type="text/html" charset="utf-8" />
    5.   <script type="text/网页特效">
    6.   function startUpload() {
    7.   document.getElementById('processing').innerHTML = 'loding...';
    8.   return true;
    9.   }
    10.   function stopUpload(rel){
    11.   var msg;
    12.   switch (rel) {
    13.   case 0:
    14.   msg = "上传成功";
    15.   break;
    16.   case 1:
    17.   msg = "上传的文件超过限制";
    18.   break;
    19.   case 2:
    20.   msg = "只能上传图片文件";
    21.   break;
    22.   default:
    23.   msg = "上传文件失败";
    24.   }
    25.   document.getElementById('processing').innerHTML = msg;
    26.   }
    27.   </script>
    28.   </head>
    29.   <body>
    30.   <div style="text-align:center">
    31.   <div id="processing"></div>
    32.   <form action="upload.php教程" method="post" enctype="multipart/form-data" target="form-target" onsubmit="startUpload();">
    33.   <input type="hidden" name="MAX_FILE_SIZE" value="1000000" />
    34.   <input type="file" name="myfile" />
    35.   <input type="submit" name="sub" value="upload" />
    36.   </form>
    37.   <iframe style="width:0; height:0; border:0;" name="form-target"></iframe>
    38.   </div>
    39.   </body>
    40.   </html>
    41.   php代码
    42.   <?php
    43.   sleep(2);
    44.   $fileTypes = array('jpg','png','gif','bmp');
    45.   $result = null;
    46.   $uploadDir = './upfiles';
    47.   $maxSize = 1 * pow(2,20);
    48.   if ($_SERVER['REQUEST_METHOD'] == 'POST' && isset($_POST['sub'])) {
    49.   $myfile = $_FILES['myfile'];
    50.   $myfileType = substr($myfile['name'], strrpos($myfile['name'], ".") + 1);
    51.   if ($myfile['size'] > $maxSize) {
    52.   $result = 1;
    53.   } else if (!in_array($myfileType, $fileTypes)) {
    54.   $result = 2;
    55.   } elseif (is_uploaded_file($myfile['tmp_name'])) {
    56.   $toFile = $uploadDir . '/' . $myfile['name'];
    57.   if (@move_uploaded_file($myfile['tmp_name'], $toFile)) {
    58.   $result = 0;
    59.   } else {
    60.   $result = -1;
    61.   }
    62.   } else {
    63.   $result = 1;
    64.   }
    65.   }
    66.   ?>
    67.   <script type="text/javascript">
    68.   window.top.window.stopUpload(<?php echo $result; ?>);
    69.   </script>
    复制代码
    帖子永久地址: 

    黑帽联盟 - 论坛版权1、本主题所有言论和图片纯属会员个人意见,与本论坛立场无关
    2、本站所有主题由该帖子作者发表,该帖子作者与黑帽联盟享有帖子相关版权
    3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和黑帽联盟的同意
    4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
    5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
    6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
    7、黑帽联盟管理员和版主有权不事先通知发贴者而删除本文

    您需要登录后才可以回帖 登录 | 会员注册

    发布主题 !fastreply! 收藏帖子 返回列表 搜索
    回顶部