一、简介

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

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

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

二、配置

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

  1. <?php
  2.  
  3. return [
  4.  
  5. /*
  6. |--------------------------------------------------------------------------
  7. | Default Filesystem Disk
  8. |--------------------------------------------------------------------------
  9. |
  10. | Here you may specify the default filesystem disk that should be used
  11. | by the framework. A "local" driver, as well as a variety of cloud
  12. | based drivers are available for your choosing. Just store away!
  13. |
  14. | Supported: "local", "ftp", "s3", "rackspace"
  15. |
  16. */
  17.  
  18. // 默认使用本地端空间 支持 "local", "ftp", "s3", "rackspace"
  19. 'default' => 'local',
  20.  
  21. /*
  22. |--------------------------------------------------------------------------
  23. | Default Cloud Filesystem Disk
  24. |--------------------------------------------------------------------------
  25. |
  26. | Many applications store files both locally and in the cloud. For this
  27. | reason, you may specify a default "cloud" driver here. This driver
  28. | will be bound as the Cloud disk implementation in the container.
  29. |
  30. */
  31.  
  32. // 云存储使用 Amazon S3
  33. 'cloud' => 's3',
  34.  
  35. /*
  36. |--------------------------------------------------------------------------
  37. | Filesystem Disks
  38. |--------------------------------------------------------------------------
  39. |
  40. | Here you may configure as many filesystem "disks" as you wish, and you
  41. | may even configure multiple disks of the same driver. Defaults have
  42. | been setup for each driver as an example of the required options.
  43. |
  44. */
  45.  
  46. 'disks' => [
  47.  
  48. // 本地端的local空间
  49. 'local' => [
  50. 'driver' => 'local',
  51. 'root' => storage_path('app'),
  52. ],
  53.  
  54. // 本地端的public空间
  55. 'public' => [
  56. 'driver' => 'local',
  57. 'root' => storage_path('app/public'),
  58. 'visibility' => 'public',
  59. ],
  60.  
  61. // 新建一个本地端uploads空间(目录) 用于存储上传的文件
  62. 'uploads' => [
  63.  
  64. 'driver' => 'local',
  65.  
  66. // 文件将上传到storage/app/uploads目录
  67. 'root' => storage_path('app/uploads'),
  68.  
  69. // 文件将上传到public/uploads目录 如果需要浏览器直接访问 请设置成这个
  70. //'root' => public_path('uploads'),
  71. ],
  72.  
  73. // Amazon S3 相关配置
  74. 's3' => [
  75. 'driver' => 's3',
  76. 'key' => 'your-key',
  77. 'secret' => 'your-secret',
  78. 'region' => 'your-region',
  79. 'bucket' => 'your-bucket',
  80. ],
  81.  
  82. ],
  83.  
  84. ];

三、代码实现文件上传

1. 控制器代码

  1. <?php
  2.  
  3. namespace App\Http\Controllers;
  4.  
  5. use Illuminate\Http\Request;
  6. use App\Http\Requests;
  7. use Illuminate\Support\Facades\Storage;
  8.  
  9. class FileController extends Controller
  10. {
  11.  
  12. // 文件上传方法
  13. public function upload(Request $request)
  14. {
  15.  
  16. if ($request->isMethod('post')) {
  17.  
  18. $file = $request->file('picture');
  19.  
  20. // 文件是否上传成功
  21. if ($file->isValid()) {
  22.  
  23. // 获取文件相关信息
  24. $originalName = $file->getClientOriginalName(); // 文件原名
  25. $ext = $file->getClientOriginalExtension(); // 扩展名
  26. $realPath = $file->getRealPath(); //临时文件的绝对路径
  27. $type = $file->getClientMimeType(); // image/jpeg
  28.  
  29. // 上传文件
  30. $filename = date('Y-m-d-H-i-s') . '-' . uniqid() . '.' . $ext;
  31. // 使用我们新建的uploads本地存储空间(目录)
  32. //这里的uploads是配置文件的名称
  33. $bool = Storage::disk('uploads')->put($filename, file_get_contents($realPath));
  34. var_dump($bool);
  35.  
  36. }
  37.  
  38. }
  39.  
  40. return view('upload');
  41. }
  42. }

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

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="renderer" content="webkit">
  6. <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  7. <meta name="csrf-token" content="{{ csrf_token() }}">
  8. <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
  9. <meta name="apple-mobile-web-app-status-bar-style" content="black">
  10. <meta name="apple-mobile-web-app-capable" content="yes">
  11. <meta name="format-detection" content="telephone=no">
  1. <link rel="stylesheet" href="/static/layui-v2.1.7/css/layui.css" />
    <script src="/static/layui-v2.1.7/layui.js"></script>
  1. <link rel="stylesheet" href="/static/css/bootstrap-4.0.0-beta.2/css/bootstrap.min.css" />
  2. <script src="/static/js/jquery/jquery-3.2.1.min.js"></script>
  3. <script src="/static/js/popper/popper.min.js"></script>
  4. <script src="/static/css/bootstrap-4.0.0-beta.2/js/bootstrap.min.js"></script>
  5. <link rel="stylesheet" href="/static/css/index.css" />
  6. <link href="/static/bootstrap-fileinput/css/fileinput.css" media="all" rel="stylesheet" type="text/css"/>
  7. <link href="/static/css/font-awesome-4.7.0/css/font-awesome.min.css" media="all" rel="stylesheet" type="text/css"/>
  8. <link href="/static/bootstrap-fileinput/themes/explorer-fa/theme.css" media="all" rel="stylesheet" type="text/css"/>
  9. <script src="/static/bootstrap-fileinput/js/plugins/sortable.js" type="text/javascript"></script>
  10. <script src="/static/bootstrap-fileinput/js/fileinput.js" type="text/javascript"></script>
  11. <script src="/static/bootstrap-fileinput/js/locales/zh.js" type="text/javascript"></script>
  12. <script src="/static/bootstrap-fileinput/themes/explorer-fa/theme.js" type="text/javascript"></script>
  13. <script src="/static/bootstrap-fileinput/themes/fa/theme.js" type="text/javascript"></script>
  14.  
  15. <title>报表上传</title>
  16. </head>
  17. <body>
  18.  
  19. <div class="layui-body">
  20.  
  21. <div style="padding: 15px;">
  22. <blockquote class="layui-elem-quote">
  23. 报表上传
  24. </blockquote>
  25. </div>
  26.  
  27. <div class="container">
  28.  
  29. <div class="container kv-main">
  30. <form enctype="multipart/form-data" method="post">
  31. <label class="control-label">Select File</label>
  32. <input id="input-b5" name="input-b5" type="file" multiple>
  33. {{ csrf_field() }}
  34. </form>
  35.  
  36. </div>
  37.  
  38. </div>
  39.  
  40. </div>
  41.  
  42. </body>
  43. <script>
  44.  
  45. $(document).ready(function(){
  46. $("#input-b5").fileinput({
  47. showCaption: false,
  48. theme: 'fa',
  49. language: 'zh',
  50. uploadUrl: './upload',
  51. allowedFileExtensions: ['jpg', 'png', 'gif']
  52. });
  53. });
  54. $.ajaxSetup({
  55. headers: {
  56. 'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
  57. }
  58. });
  59.  
  60. </script>
  61.  
  62. </html>

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

  1. <form method="post" enctype="multipart/form-data" >
  2. <input type="file" name="picture">
  3. <button type="submit"> 提交 </button>
  4. </form>

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

  1. Laravel 5.2 教程 - 文件上传

    一.简介 Laravel 有很棒的文件系统抽象层,是基于 Frank de Jonge 的 Flysystem 扩展包. Laravel 集成的 Flysystem 提供了简单的接口,可以操作本地端空 ...

  2. php laravel 帧 该文件上传

    好,我承认我的忠告. 今天laravel框架编写一个文件上传部分.总能找到不正确的路径.但是,终于攻克. 以下我分享一下自己的学习体会吧. client <form method="P ...

  3. PHP高级教程-文件上传

    PHP 文件上传 通过 PHP,可以把文件上传到服务器. 本章节实例在 test 项目下完成,目录结构为: test |-----upload # 文件上传的目录 |-----form.html # ...

  4. Laravel请求/Cookies/文件上传

    一.HTTP请求 1.基本示例:通过依赖注入获取当前 HTTP 请求实例,应该在控制器的构造函数或方法中对Illuminate\Http\Request 类进行类型提示,当前请求实例会被服务容器自动注 ...

  5. Spring Boot 教程 - 文件上传下载

    在日常的开发工作中,基本上每个项目都会有各种文件的上传和下载,大多数文件都是excel文件,操作excel的JavaAPI我用的是apache的POI进行操作的,POI我之后会专门讲到.此次我们不讲如 ...

  6. laravel中的文件上传到本地+七牛云上传

    首先在filesystems.php 配置好上传的文件的目录起名为upload 在Storage/目录下面 目录下面的app/upload 如果没有这个文件会自动创建 这里的名字upload名字是跟控 ...

  7. IT兄弟连 JavaWeb教程 文件上传技术

    在Web应用系统开发中,文件上传和下载功能是非常常用的功能. 对于文件上传,浏览器在上传的过程中是将文件以流的形式提交到服务器端的,如果直接使用Servlet获取上传文件的输入流然后再解析里面的请求参 ...

  8. Laravel - 上手实现 - 文件上传、保存到 public 目录下

    1.为了访问方便,将上传的文件保存在 public 目录下,需要进行修改配置. 找到 config/filesystems.php 文件然后修改 root.具体如下: 'local' => [ ...

  9. laravel oauth2.0 文件上传报错

    报错信息:   "message": "Invalid stream or file provided for UploadedFile",    " ...

随机推荐

  1. C++ cout输出保留小数

    参考: http://www.cnblogs.com/wushuaiyi/p/4439361.html http://blog.csdn.net/edricbjtu/article/details/4 ...

  2. CentOS 6.9配置网卡IP/网关/DNS命令详细介绍及一些常用网络配置命令(转)

    一.IP 即时生效(重启后失效): ifconfig eth0 192.168.1.102 netmask 255.255.255.0 //添加IP地址 route add default gw 19 ...

  3. 【java】实体类中 按照特定的字段 进行升序/降序 排序

    背景: 实际页面上  所有的分值都是按照JSON格式存储在一个字符串中 存储在同一个字段中: {"ownPTotal":"10>0","ownO ...

  4. Oracle 11gR2 RAC连接时ORA-12545错误

    刚装成的Oracle 11gR2的RAC集群 三个节点 创建好数据库,一切都在正常的进行中 然后去安装了一个oracle client,进行链接时出现了ORA-12545 然后简单的baidu了一下, ...

  5. jquery next()方法

    1.html代码 <!DOCTYPE html> <html> <head> <script type="text/javascript" ...

  6. HDU 4886 TIANKENG’s restaurant(Ⅱ) hash+dfs

    题意: 1.找一个字符串s使得 s不是给定母串的子串 2.且s要最短 3.s在最短情况下字典序最小 hash.,,结果t掉了...加了个姿势怪异的hash值剪枝才过.. #include <cs ...

  7. xampp Apache Access forbidden! Error 403解决方法

    今天下载了最新的xampp,配置了一个虚拟主机,一直在报错,Access forbidden! Error 403 这很明显是服务器不允许访问文件,但是我的虚拟主机配置如下: DocumentRoot ...

  8. Linux pci驱动源码

    #include <linux/kernel.h>#include <linux/errno.h>#include <linux/module.h>#include ...

  9. unity pbr

    https://disney-animation.s3.amazonaws.com/library/s2012_pbs_disney_brdf_notes_v2.pdf 参数

  10. DXR

    https://github.com/ConfettiFX/The-Forge/blob/master/CommonRaytracing_3/ThirdParty/DXR/doc/D3D12%20Ra ...