在thinkphp5中:有上传文件一章:

https://www.kancloud.cn/manual/thinkphp5/155159


如果对于文件上传这一章,不了解,就先看下面的,再来看这一段。

下面我们自定义两个规则。

1.datea规则,年月/时分秒.(3位随机数)

/201706/164030789

2.ymmd5规则,年/月/md5

修改框架文件:thinkphp/library/think/File.php。


增加两个case:

case 'datea':
case 'ymmd5':

这样就可以了。


/**
 * 获取保存文件名
 * @param  string|bool   $savename    保存的文件名 默认自动生成
 * @return string
 */
protected function buildSaveName($savename)
{
    if (true === $savename) {
        // 自动生成文件名
        if ($this->rule instanceof \Closure) {
            $savename = call_user_func_array($this->rule, [$this]);
        } else {
            switch ($this->rule) {
                case 'date':
                    $savename = date('Ymd') . DS . md5(microtime(true));
                    break;
                case 'datea':
                    $savename = date('Ym') . DS . date('His') .rand(100,999));
                    break;
                case 'ymmd5':
                    $savename = date('Y') . DS .date('m') . DS. $this->hash('md5');
                    break;
                default:
                    if (in_array($this->rule, hash_algos())) {
                        $hash     = $this->hash($this->rule);
                        $savename = substr($hash, 0, 2) . DS . substr($hash, 2);
                    } elseif (is_callable($this->rule)) {
                        $savename = call_user_func($this->rule);
                    } else {
                        $savename = date('Ymd') . DS . md5(microtime(true));
                    }
            }
        }
    } elseif ('' === $savename) {
        $savename = $this->getInfo('name');
    }
    if (!strpos($savename, '.')) {
        $savename .= '.' . pathinfo($this->getInfo('name'), PATHINFO_EXTENSION);
    }
    return $savename;
}


如果对于文件上传这一章,不了解,就先看下面的。


假设表单代码如下:

<form action="/index/index/upload" enctype="multipart/form-data" method="post">
<input type="file" name="p_w_picpath" /> <br> 
<input type="submit" value="上传" /> 
</form>


然后在控制器中添加如下的代码:

public function upload(){    
    // 获取表单上传文件 例如上传了001.jpg
    $file = request()->file('p_w_picpath');    
    // 移动到框架应用根目录/public/uploads/ 目录下
    $info = $file->move(ROOT_PATH . 'public' . DS . 'uploads');    
    if($info){        
    // 成功上传后 获取上传信息
        // 输出 jpg
        echo $info->getExtension();        
        // 输出 20160820/42a79759f284b767dfcb2a0197904287.jpg
        echo $info->getSaveName();       
         // 输出 42a79759f284b767dfcb2a0197904287.jpg
        echo $info->getFilename(); 
    }else{       
     // 上传失败获取错误信息
        echo $file->getError();
    }
}


move方法成功的话返回的是一个\think\File对象,你可以对上传后的文件进行后续操作。


多文件上传

如果你使用的是多文件上传表单,例如:

<form action="/index/index/upload" enctype="multipart/form-data" method="post">
<input type="file" name="p_w_picpath[]" /> <br> 
<input type="file" name="p_w_picpath[]" /> <br> 
<input type="file" name="p_w_picpath[]" /> <br> 
<input type="submit" value="上传" /> 
</form>

控制器代码可以改成:

public function upload(){    
// 获取表单上传文件
    $files = request()->file('p_w_picpath');    
    foreach($files as $file){    
        // 移动到框架应用根目录/public/uploads/ 目录下
        $info = $file->move(ROOT_PATH . 'public' . DS . 'uploads');     
           if($info){           
            // 成功上传后 获取上传信息
            // 输出 jpg
            echo $info->getExtension(); 
            // 输出 42a79759f284b767dfcb2a0197904287.jpg
            echo $info->getFilename(); 
        }else{            // 上传失败获取错误信息
            echo $file->getError();
        }    
    }
}

上传规则

默认情况下,会在上传目录下面生成以当前日期为子目录,以微秒时间的md5编码为文件名的文件,例如上面生成的文件名可能是:

/home/www/upload/20160510/42a79759f284b767dfcb2a0197904287.jpg

我们可以指定上传文件的命名规则,使用rule方法即可,例如:

// 获取表单上传文件 例如上传了001.jpg
$file = request()->file('p_w_picpath');
// 移动到服务器的上传目录 并且使用md5规则
$file->rule('md5')->move('/home/www/upload/');

最终生成的文件名类似于:

/home/www/upload/72/ef580909368d824e899f77c7c98388.jpg

系统默认提供了几种上传命名规则,包括:

规则描述
date根据日期和微秒数生成
md5对文件使用md5_file散列生成
sha1对文件使用sha1_file散列生成

其中md5和sha1规则会自动以散列值的前两个字符作为子目录,后面的散列值作为文件名。

如果需要使用自定义命名规则,可以在rule方法中传入函数或者方法,例如:

// 获取表单上传文件 例如上传了001.jpg
$file = request()->file('p_w_picpath');
// 移动到服务器的上传目录 并且使用uniqid规则
$file->rule('uniqid')->move('/home/www/upload/');

生成的文件名类似于:

/home/www/upload/573d3b6d7abe2.jpg

如果你希望保留原文件名称,可以使用:

// 获取表单上传文件 例如上传了001.jpg
$file = request()->file('p_w_picpath');
// 移动到服务器的上传目录 并且使用原文件名
$file->move('/home/www/upload/','');

默认情况下,会覆盖服务器上传目录下的同名文件,如果不希望覆盖,可以使用:

// 获取表单上传文件 例如上传了001.jpg
$file = request()->file('p_w_picpath');
// 移动到服务器的上传目录 并且设置不覆盖
$file->move('/home/www/upload/',true,false);

----------  招募未来大神 -----------------------

如果您有利他之心,乐于帮助他人,乐于分享
如果您遇到php问题,百度且问了其他群之后仍没得到解答

欢迎加入,PHP技术问答群,QQ群:292626152

教学相长!帮助他人,自己也会得到提升!

为了珍惜每个人的宝贵时间,请大家不要闲聊。

愿我们互相帮助,共同成长!

加入时留言暗号,php,ajax,thinkphp,yii...