PHP-Laravel上传文件

Files

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <form action="/upload" method="post" enctype="multipart/form-data">
        <p>
            {{csrf_field()}}
            PHOTO:
            <input type="file" name="img" id="">
        </p>

        <p>
            <input type="submit" value="提交">
        </p>
    </form>
</body>
</html>

获取上传文件

你可以使用 Illuminate\Http\Request 实例中的 file 方法获取上传的文件。file方法返回的对象是 Symfony\Component\HttpFoundation\File\UploadedFile 类的实例,该类继承了 PHPSplFileInfo 类,并提供了许多和文件交互的方法:

$file = $request->file('photo');
$file = $request->photo;

你可以使用请求的 hasFile 方法确认上传的文件是否存在:

if ($request->hasFile('photo')) {
    //
}

确认上传的文件是否有效

除了检查上传的文件是否存在外,你也可以通过 isValid 方法验证上传的文件是否有效:

if ($request->file('photo')->isValid()) {
    //
}

文件路径&拓展

UploadedFile 这个类也包含了访问文件完整路径和扩展的方法。extension 方法会尝试根据文件内容猜测文件的扩展名。猜测结果可能不同于客户端原始的扩展名:

$path = $request->photo->path();
$extension = $request->photo->extension();

其他上传的方法

UploadedFile 的实例还有许多可用的方法,可以到 该对象的 API 文档 了解这些方法的详细信息。

储存上传文件

在设置好 文件系统 的配置信息后,你可以使用 UploadedFilestore 方法把上传文件储存到本地磁盘,或者是亚马逊 S3 云存储上。
store 方法允许存储文件到相对于文件系统根目录配置的路径。这个路径不能包含文件名,名称将使用 MD5 散列文件内容自动生成。
store 方法还接受一个可选的第二个参数,用于文件存储到磁盘的名称。这个方法会返回文件相对于磁盘根目录的路径:

$path = $request->photo->store('images');
$path = $request->photo->store('images', 's3');

如果你不想自动生成文件名,那么可以使用 storeAs 方法去设置路径,文件名和磁盘名作为方法参数:

$path = $request->photo->storeAs('images', 'filename.jpg');
$path = $request->photo->storeAs('images', 'filename.jpg', 's3');

上传本地的例子

 // 文件上传处理
 public function upload(Request $request){    
     // 判断文件是否上传
     if ($request->hasFile('img')) {
         // 获取后缀名
         $ext=$request->file('img')->getClientOriginalExtension();
         // 新的文件名
         $newFile=time().rand().".".$ext;
         // 上传文件操作
         $request->file('img')->move('./Uploads',$newFile);
     }else{
         // 回到上一个页面
         return back();
     }
 }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值