Laravel 5 教程 - 文件上传

一、简介

Laravel 有很棒的文件系统抽象层,是基于 Frank de Jonge 的 Flysystem 扩展包。 Laravel 集成的 Flysystem 提供了简单的接口,可以操作本地端空间、 Amazon S3 、 Rackspace Cloud Storage 。更方便的是,它可以非常简单的切换不同保存方式,但仍使用相同的 API 操作!

默认使用本地端空间。当然,你也可以设置多组磁盘,甚至在多个磁盘使用相同的驱动。Laravel文件系统提供了非常强大的功能,但是本文只介绍常用的文件上传功能。

本文通过介绍使用本地端空间来介绍Laravel中文件上传的使用。

二、配置

文件系统的配置文件在 config/filesystems.php 文件中,此处我们新建一个uploads本地磁盘空间用于存储上传的文件,具体配置项及说明如下:

<?php

return [

    /*
    |--------------------------------------------------------------------------
    | Default Filesystem Disk
    |--------------------------------------------------------------------------
    |
    | Here you may specify the default filesystem disk that should be used
    | by the framework. A "local" driver, as well as a variety of cloud
    | based drivers are available for your choosing. Just store away!
    |
    | Supported: "local", "ftp", "s3", "rackspace"
    |
    */

    // 默认使用本地端空间 支持 "local", "ftp", "s3", "rackspace"
    ‘default‘ => ‘local‘,

    /*
    |--------------------------------------------------------------------------
    | Default Cloud Filesystem Disk
    |--------------------------------------------------------------------------
    |
    | Many applications store files both locally and in the cloud. For this
    | reason, you may specify a default "cloud" driver here. This driver
    | will be bound as the Cloud disk implementation in the container.
    |
    */

    // 云存储使用 Amazon S3
    ‘cloud‘ => ‘s3‘,

    /*
    |--------------------------------------------------------------------------
    | Filesystem Disks
    |--------------------------------------------------------------------------
    |
    | Here you may configure as many filesystem "disks" as you wish, and you
    | may even configure multiple disks of the same driver. Defaults have
    | been setup for each driver as an example of the required options.
    |
    */

    ‘disks‘ => [

        // 本地端的local空间
        ‘local‘ => [
            ‘driver‘ => ‘local‘,
            ‘root‘ => storage_path(‘app‘),
        ],

        // 本地端的public空间
        ‘public‘ => [
            ‘driver‘ => ‘local‘,
            ‘root‘ => storage_path(‘app/public‘),
            ‘visibility‘ => ‘public‘,
        ],

        // 新建一个本地端uploads空间(目录) 用于存储上传的文件
        ‘uploads‘ => [

            ‘driver‘ => ‘local‘,

            // 文件将上传到storage/app/uploads目录
            ‘root‘ => storage_path(‘app/uploads‘),

            // 文件将上传到public/uploads目录 如果需要浏览器直接访问 请设置成这个
            //‘root‘ => public_path(‘uploads‘),
        ],

        // Amazon S3 相关配置
        ‘s3‘ => [
            ‘driver‘ => ‘s3‘,
            ‘key‘ => ‘your-key‘,
            ‘secret‘ => ‘your-secret‘,
            ‘region‘ => ‘your-region‘,
            ‘bucket‘ => ‘your-bucket‘,
        ],

    ],

];

三、代码实现文件上传

1. 控制器代码

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Requests;
use Illuminate\Support\Facades\Storage;

class FileController extends Controller
{

    // 文件上传方法
    public function upload(Request $request)
    {

        if ($request->isMethod(‘post‘)) {

            $file = $request->file(‘picture‘);

            // 文件是否上传成功
            if ($file->isValid()) {

                // 获取文件相关信息
                $originalName = $file->getClientOriginalName(); // 文件原名
                $ext = $file->getClientOriginalExtension();     // 扩展名
                $realPath = $file->getRealPath();   //临时文件的绝对路径
                $type = $file->getClientMimeType();     // image/jpeg

                // 上传文件
                $filename = date(‘Y-m-d-H-i-s‘) . ‘-‘ . uniqid() . ‘.‘ . $ext;
                // 使用我们新建的uploads本地存储空间(目录)
                //这里的uploads是配置文件的名称
                $bool = Storage::disk(‘uploads‘)->put($filename, file_get_contents($realPath));
                var_dump($bool);

            }

        }

        return view(‘upload‘);
    }
}    

2-1.upload.blade.php 模板代码(上传组件为bootstrap-fileinput)如果太乱,可以看下面的最简单的页面:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta name="csrf-token" content="{{ csrf_token() }}">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="format-detection" content="telephone=no">
<link rel="stylesheet"  href="/static/layui-v2.1.7/css/layui.css" /><script src="/static/layui-v2.1.7/layui.js"></script>
<link rel="stylesheet" href="/static/css/bootstrap-4.0.0-beta.2/css/bootstrap.min.css" />
<script src="/static/js/jquery/jquery-3.2.1.min.js"></script>
<script src="/static/js/popper/popper.min.js"></script>
<script src="/static/css/bootstrap-4.0.0-beta.2/js/bootstrap.min.js"></script>
<link rel="stylesheet" href="/static/css/index.css" />
<link href="/static/bootstrap-fileinput/css/fileinput.css" media="all" rel="stylesheet" type="text/css"/>
<link href="/static/css/font-awesome-4.7.0/css/font-awesome.min.css" media="all" rel="stylesheet" type="text/css"/>
<link href="/static/bootstrap-fileinput/themes/explorer-fa/theme.css" media="all" rel="stylesheet" type="text/css"/>
<script src="/static/bootstrap-fileinput/js/plugins/sortable.js" type="text/javascript"></script>
<script src="/static/bootstrap-fileinput/js/fileinput.js" type="text/javascript"></script>
<script src="/static/bootstrap-fileinput/js/locales/zh.js" type="text/javascript"></script>
<script src="/static/bootstrap-fileinput/themes/explorer-fa/theme.js" type="text/javascript"></script>
<script src="/static/bootstrap-fileinput/themes/fa/theme.js" type="text/javascript"></script>

    <title>报表上传</title>
</head>
<body>

<div class="layui-body">

        <div style="padding: 15px;">
            <blockquote class="layui-elem-quote">
                报表上传
            </blockquote>
        </div>

    <div class="container">

        <div class="container kv-main">
            <form enctype="multipart/form-data" method="post">
                <label class="control-label">Select File</label>
                <input id="input-b5" name="input-b5" type="file" multiple>
                {{ csrf_field() }}
            </form>

        </div>

    </div>

</div>

</body>
<script>

    $(document).ready(function(){
        $("#input-b5").fileinput({
            showCaption: false,
            theme: ‘fa‘,
            language: ‘zh‘,
            uploadUrl: ‘./upload‘,
            allowedFileExtensions: [‘jpg‘, ‘png‘, ‘gif‘]
        });
    });
    $.ajaxSetup({
        headers: {
            ‘X-CSRF-TOKEN‘: $(‘meta[name="csrf-token"]‘).attr(‘content‘)
        }
    });

</script>

</html>

2-2. 最基础的 upload.blade.php 模板代码:

<form method="post" enctype="multipart/form-data" >
    <input type="file" name="picture">
    <button type="submit"> 提交 </button>
</form>
时间: 2024-08-30 10:54:47

Laravel 5 教程 - 文件上传的相关文章

PHP高级教程-文件上传

PHP 文件上传 通过 PHP,可以把文件上传到服务器. 本章节实例在 test 项目下完成,目录结构为: test |-----upload # 文件上传的目录 |-----form.html # 表单文件 |-----upload_file.php # php 上传代码 源码下载 创建一个文件上传表单 允许用户从表单上传文件是非常有用的. 请看下面这个供上传文件的 HTML 表单: <html> <head> <meta charset="utf-8"

laravel框架多文件上传

1.首先先在laravel根目录下执行 $ php artisan storage:link ,产生映射文件 2.编写controller层 // 文件上传 public function upload(Request $request){ // 判断是否有上传文件字段 if ( $request->file() ){ //定义一个空数组存放文件列表 $files = []; // 循环获取所有文件字段 foreach ($request->allFiles() as $file){ // 定

php laravel 框架 之文件上传

客户端 <form method="POST" action="" enctype="muitipart/form-data"> <input type="file" name="myfile" /> <input type="submit" name="submit" value="Submit" /> <

laravel oauth2.0 文件上传报错

报错信息:   "message": "Invalid stream or file provided for UploadedFile",    "exception": "InvalidArgumentException",    "file": "E:\\unionnet\\vendor\\zendframework\\zend-diactoros\\src\\UploadedFile.ph

文件上传类代码(php例子)

这里是来自网络朋友的一个实现的文件上传类代码,我们详细的介绍了每个变量的用处,下面看看吧,有需要可以参考一下. 这里是来自网络朋友的一个实现的文件上传类代码,我们详细的介绍了每个变量的用处,下面看看吧,有需要可以参考一下. <?php教程 /**  * 文件上传类  */ class uploadFile { public $max_size = '1000000';//设置上传文件大小  public $file_name = 'date';//重命名方式代表以时间命名,其他则使用给予的名称 

【转】NodeJS教程--基于ExpressJS框架的文件上传

本文是翻译的一篇文章,原文地址:Handle File Uploads in Express (Node.js). 在NodeJS发展早期上传文件是一个较难操作的功能,随后出现了formidable.它开了一个好头,然而上传文件仍然不是那么容易.在此之后又出现了基于原文作者的教程(tutorial on handling POST requests in Express)而实现的工具connect-form.它让文件上传的过程显得简单了一些. 随着NodeJS社区的飞速发展,让上传文件这个功能变

#laravel笔记# 文件上传

在Laravel表单请求中,获取上传的文件对象:$file=$request->file('name'): 1.在文件对象中,我们可以获得以下主要信息: //文件的扩展名 $file->getClientOriginalExtension(); //文件的原名 $file->getClientOriginalName(); //文件大小 $file->getSize(); //文件临时的绝对路径 $realpath = $file->getRealPath(); //把临时文

文件上传利器SWFUpload入门简易教程

凡做过网站开发的都应该知道表单file的确鸡肋. Ajax解决了不刷新页面提交表单,但是却没有解决文件上传不刷新页面,当然也有其它技术让不刷新页面而提交文件,该技术主要是利用隐藏的iFrame, 较Ajax要麻烦许多,而且其提交方式依然在底层是使用的表单file,这里我们不详谈.而且如果是提交较小的文件,我们能接受,如果提交的文件较大,我 们便要忍受很长的等待时间,而浏览器却没有任何提示,我们也没有办法知道文件上传的进度… 但是现在,网上出现了一个名为SWFUpload的上传组件,该组件利用Fl

【技术博客】Postman接口测试教程 - 环境、附加验证、文件上传测试

Postman接口测试教程 - 环境.附加验证.文件上传测试 v1.0 作者:ZBW 前言 继利用Postman和Jmeter进行接口性能测试之后,我们发现Postman作为一款入门容易的工具,其内置的一些高级功能足够帮助我们对网站进行全面的接口测试.本文首先将介绍两个比较关键的功能:环境(Environment)和附加代码(Pre-request Script和Tests),这两个功能能够帮助我们对接口进行更加复杂的验证,如验证接口返回的信息等.除此之外,本文还将介绍文件上传测试的运行方式.