您的位置:首页 > 编程语言 > PHP开发

PHP-Laravel上传文件

2018-03-08 11:55 225 查看

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
类的实例,该类继承了
PHP
SplFileInfo
类,并提供了许多和文件交互的方法:

$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 文档 了解这些方法的详细信息。

储存上传文件

在设置好 文件系统 的配置信息后,你可以使用
UploadedFile
store
方法把上传文件储存到本地磁盘,或者是亚马逊 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();
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: