欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

php文件上傳及下載附帶顯示文件及目錄功能

 更新時間:2017年04月27日 15:48:24   作者:v斌v  
這篇文章主要介紹了php文件上傳及下載附帶顯示文件及目錄功能,需要的朋友可以參考下

主頁面wenjianceshi.php

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>文件</title>
<link href="../FENGZHUANG/bootstrap/css/bootstrap.min.css" rel="external nofollow" rel="stylesheet" type="text/css" />
<script src="../FENGZHUANG/jquery-3.1.1.min.js"></script>
<script src="../FENGZHUANG/bootstrap/js/bootstrap.min.js"></script>
<style type="text/css">
  *{
    font-family:"微軟雅黑";}
  #wai{width:400px;
    margin:0 auto;
    padding:0px;}
  #chuanshu{
    width:400px;
    margin:0 auto;
    padding:0px;}
  .waibtn{
    width:100%;;
    height:30px;}
  .wjm,.wjbtn{
    width:50%;
    height:100%;
    float:left;
    }
</style>
</head>
<body>
<div id="chuanshu">
  <form role="form" action="upload.php" method="post" enctype="multipart/form-data">
   <div class="form-group">
    <label for="inputfile">文件輸入</label>
    <input type="file" name="file" id="inputfile">
   </div>
   <button type="submit" class="btn btn-default">上傳</button>
  </form>
</div>
<br /><br /><br />
<div id="wai">
<?php
session_start();
//定義目錄
$fname = "./a";//需要顯示的目錄
if(!empty($_SESSION["fname"]))
{
  $fname = $_SESSION["fname"];
}
$pname = dirname($fname); //取上級目錄
if(realpath($fname)=="D:\\wamp\\www\\lt\\a")//注意路徑的匹配
{
}//到達了需要顯示的最上層目錄就不顯示上一層標簽了
else
{
  echo "<button type='button' id='prev' class='btn waibtn btn-success' url='{$pname}'>返回上一層</button>";
}
//遍歷目錄下的所有文件顯示
$arr = glob($fname."/*");
foreach($arr as $v)
{
  $name = basename($v); //從完整路徑中取文件名
  $name = iconv("gbk","utf-8",$name);
  if(is_dir($v))
  {
    echo "<button type='button' class='btn dir waibtn btn-primary' url='{$v}'>{$name}</button>";
  }
  else
  {
    echo "<button type='button' class='btn waibtn item btn-default' url='{$v}'><div class='wjm'>{$name}</div><div class='wjbtn'><a href='download.php? url={$v}'><input type='button' value='下載' url='{$v}' class='download btn btn-warning btn-xs' /></a>&nbsp;&nbsp;</div></button>";
  }
}
?>
</div>
</body>
<script type="text/javascript">
$(".dir").click(function(){
    var url = $(this).attr("url");
    $.ajax({
        url:"chuli2.php",
        data:{url:url},
        type:"POST",
        dataType:"TEXT",
        success: function(data){
            window.location.href="wenjianceshi.php" rel="external nofollow" rel="external nofollow" ;
          }
      });
  })
$("#prev").click(function(){
  var url = $(this).attr("url");
  $.ajax({
      url:"chuli2.php",
      data:{url:url},
      type:"POST",
      dataType:"TEXT",
      success: function(data){
          window.location.href="wenjianceshi.php" rel="external nofollow" rel="external nofollow" ;
        }
    });
  })</script>
</html>

顯示:

上傳處理頁面upload.php

<?php
if($_FILES["file"]["error"])
{
  echo $_FILES["file"]["error"];
}
else
{
  if($_FILES["file"]["size"]<10240000)
  {
    //防止文件名重復
    $filename = "./a/".time().$_FILES["file"]["name"];
    //轉碼
    $filename = iconv("UTF-8","gb2312",$filename);
    if(file_exists($filename))
    {
      echo "該文件已存在";
    }
    else
    {
      //保存文件
      move_uploaded_file($_FILES["file"]["tmp_name"],$filename);
      header("location:wenjianchuanshu.php");
    }
  }
  else
  {
    echo "文件類型不對";
  }
}

點擊選擇文件之后選中了文件會顯示:

點擊上傳即可。

下載處理頁面download.php

<?php
$url = $_GET["url"];
$bname = basename($url);
header("Content-type:text/html;charset=utf-8"); 
$file_name="{$bname}"; 
//用以解決中文不能顯示出來的問題 
$file_name=iconv("utf-8","gb2312",$file_name); 
$file_sub_path=$_SERVER['DOCUMENT_ROOT']; 
$file_path="{$url}"; 
//首先要判斷給定的文件存在與否 
if(!file_exists($file_path)){ 
echo "沒有該文件"; 
return ; 
} 
$fp=fopen($file_path,"r"); 
$file_size=filesize($file_path); 
//下載文件需要用到的頭 
Header("Content-type: application/octet-stream"); 
Header("Accept-Ranges: bytes"); 
Header("Accept-Length:".$file_size); 
Header("Content-Disposition: attachment; filename=".$file_name); 
$buffer=10240000; 
$file_count=0; 
//向瀏覽器返回數據 
while(!feof($fp) && $file_count<$file_size){ 
$file_con=fread($fp,$buffer); 
$file_count+=$buffer; 
echo $file_con; 
} 
fclose($fp);

點擊下載會彈出下載框,然后進行下載即可。

點擊文件夾或者上一層的處理頁面chuli2.php

<?php
session_start();
$url = $_POST["url"];
$_SESSION["fname"] = $url;

以上所述是小編給大家介紹的php文件上傳及下載附帶顯示文件及目錄功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

相關文章

  • 使用vs code編輯調試php配置的方法

    使用vs code編輯調試php配置的方法

    這篇文章主要介紹了使用vs code編輯調試php配置的方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • php Session無效分析資料整理

    php Session無效分析資料整理

    Session在開發(fā)中是非常重要的一個數據存儲變量了,它可以實現不同頁面之間的傳值了,下面我們來為各位介紹在使用Session時碰到過期無效的一些問題吧,需要的朋友可以參考下
    2016-11-11
  • WordPress中的shortcode短代碼功能使用詳解

    WordPress中的shortcode短代碼功能使用詳解

    WordPress中的短代碼能通過簡單的函數集合創(chuàng)建宏代碼來生成內容,方便函數調用,下面就讓我們一起來看一下WordPress中的shortcode短代碼功能使用詳解.
    2016-05-05
  • PHP生成各種常見驗證碼和Ajax驗證過程

    PHP生成各種常見驗證碼和Ajax驗證過程

    本文將通過實例講解使用PHP生成各種常見的驗證碼包括數字驗證碼、數字+字母驗證碼、中文驗證碼、算術驗證碼等等以及其Ajax驗證過程
    2016-01-01
  • Laravel中任務調度console使用方法小結

    Laravel中任務調度console使用方法小結

    這篇文章主要給大家簡單介紹了Laravel中任務調度console使用方法,并附上一個簡單的示例,希望對大家學習使用console能夠有所幫助
    2017-05-05
  • 淺談php中urlencode與rawurlencode的區(qū)別

    淺談php中urlencode與rawurlencode的區(qū)別

    下面小編就為大家?guī)硪黄獪\談php中urlencode與rawurlencode的區(qū)別。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-09-09
  • 詳解PHP用substr函數截取字符串中的某部分

    詳解PHP用substr函數截取字符串中的某部分

    這篇文章主要介紹了詳解PHP用substr函數截取字符串中的某部分,非常具有實用價值,需要的朋友可以參考下。
    2016-12-12
  • laravel5環(huán)境隱藏index.php后綴(apache)的方法

    laravel5環(huán)境隱藏index.php后綴(apache)的方法

    今天小編就為大家分享一篇laravel5環(huán)境隱藏index.php后綴(apache)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • Yii1.0 不同頁面多個驗證碼的使用實現

    Yii1.0 不同頁面多個驗證碼的使用實現

    這篇文章主要介紹了Yii1.0 不同頁面多個驗證碼的使用實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • ThinkPHP3.2.3框架Memcache緩存使用方法實例總結

    ThinkPHP3.2.3框架Memcache緩存使用方法實例總結

    這篇文章主要介紹了ThinkPHP3.2.3框架Memcache緩存使用方法,結合實例形式總結分析看thinkPHP框架下Memcache緩存各種調用方法與配置相關操作技巧,需要的朋友可以參考下
    2019-04-04

最新評論