文件下载:

html:

<html>
<body>
  <a href="1.rar">下载1.rar</a>
  <br />
  <a href="1.jpg">下载1.jpg</a> <!--会显示文件内容,而不是下载-->
  <br />
  <a href="doDownload.php?filename=1.jpg">通过程序下载1.jpg</a>
  <br />
  <a href="doDownload.php?filename=../upload/nv.jpg">下载nv.jpg</a>
</body>
</html>

php处理:

<?php 
$filename=$_GET['filename'];
//设置下载文件名
header('content-disposition:attachment;filename='.basename($filename));
header('content-length:'.filesize($filename));
readfile($filename);

文件上传:

html代码:

<html>
<body>
  <form action="doAction5.php" method="post" enctype="multipart/form-data">
    请选择您要上传的文件:<input type="file" name='myFile1' /><br/>
    请选择您要上传的文件:<input type="file" name='myFile2' /><br/>
    请选择您要上传的文件:<input type="file" name='myFile[]' /><br/>
    请选择您要上传的文件:<input type="file" name='myFile[]' /><br/>
    请选择您要上传的文件:<input type="file" name='myFile[]' multiple="multiple" /><br/>
    <input type="submit" value="上传文件" />
  </form>
</body>
</html>

php代码:

<?php 
/**
 * 得到文件扩展名
 * @param string $filename
 * @return string
 */
function getExt($filename){
  return strtolower(pathinfo($filename,PATHINFO_EXTENSION));
}

/**
 * 产生唯一字符串
 * @return string
 */
function getUniName(){
  return md5(uniqid(microtime(true),true));
}

upload.func1.php

<?php 

/**
 * 构建上传文件信息
 * @return unknown
 */
function getFiles(){
  $i=0;
  foreach($_FILES as $file){
    if(is_string($file['name'])){
      $files[$i]=$file;
      $i++;
    }elseif(is_array($file['name'])){
      foreach($file['name'] as $key=>$val){
        $files[$i]['name']=$file['name'][$key];
        $files[$i]['type']=$file['type'][$key];
        $files[$i]['tmp_name']=$file['tmp_name'][$key];
        $files[$i]['error']=$file['error'][$key];
        $files[$i]['size']=$file['size'][$key];
        $i++;
      }
    }
  }
  return $files;
  
}
/**
 * 针对于单文件、多个单文件、多文件的上传
 * @param array $fileInfo
 * @param string $path
 * @param string $flag
 * @param number $maxSize
 * @param array $allowExt
 * @return string
 */
function uploadFile($fileInfo,$path='./uploads',$flag=true,$maxSize=1048576,$allowExt=array('jpeg','jpg','png','gif')){
  //$flag=true;
  //$allowExt=array('jpeg','jpg','gif','png');
  //$maxSize=1048576;//1M
  //判断错误号
  if($fileInfo['error']===UPLOAD_ERR_OK){
    //检测上传得到小
    if($fileInfo['size']>$maxSize){
      $res['mes']=$fileInfo['name'].'上传文件过大';
    }
    $ext=getExt($fileInfo['name']);
    //检测上传文件的文件类型
    if(!in_array($ext,$allowExt)){
      $res['mes']=$fileInfo['name'].'非法文件类型';
    }
    //检测是否是真实的图片类型
    if($flag){
      if(!getimagesize($fileInfo['tmp_name'])){
        $res['mes']=$fileInfo['name'].'不是真实图片类型';
      }
    }
    //检测文件是否是通过HTTP POST上传上来的
    if(!is_uploaded_file($fileInfo['tmp_name'])){
      $res['mes']=$fileInfo['name'].'文件不是通过HTTP POST方式上传上来的';
    }
    if($res) return $res;
    //$path='./uploads';
    if(!file_exists($path)){
      mkdir($path,0777,true);