laravel实现上传图片,并且制作缩略图,按照日期存放的代码


Posted in PHP onOctober 16, 2019

先上代码吧:

前端代码:

有很多小伙伴在做表单上传文件的时候没有注意表单的上传格式是什么,就可能导致上传文件、图片不成功!

<form id="form1" name="form1" class="form-horizontal form-label-left" enctype="multipart/form-data" method="post" action="{{asset('/content/add')}}" οnsubmit="submitContent()">
{{method_field('PUT')}}
laravel里面使用method_field()函数来伪造一些http请求;

<div class="form-group">
 <label class="control-label col-md-3 col-sm-3 col-xs-12" for="main_img">展示主图 <span class="required">*</span></label>
 <div class="col-md-6 col-sm-6 col-xs-12">
 <div id="inputBox">
  <input type="file" title="请选择图片" id="mainImg" name="main_img" required multiple accept="image/png,image/jpg,image/gif,image/JPEG"/>
  <div id="mainImgBox"></div>
 </div>
 </div>
</div>
 {!! csrf_field() !!}

给表单加入token;

后端处理:

首先我使用的是Intervention Image类库来制作图片的缩略图、以及保存图片到指定位置;

关于Intervention Image类库我就不多做介绍,如有不了解的请度娘帮助;

<?php
namespace App\Http\Controllers\Admin;
 
use App\Http\Controllers\Controller;
use Image;
use Validator;
 
class ContentController extends Controller{
 public function addProcess(){
 $inputData = request()->all();
 $rules = [
  'main_img' => [ 'file','image','max:10240' ]
 ];
 $validator = Validator::make($inputData,$rules);
 if($validator->fails()){
  return back()->withErrors($validator)->withInput();
 }
 
  $photo = $inputData['main_img'];
  $file_name = uniqid().'.'.$photo->getClientOriginalExtension();
  $file_relative_path = 'assess/images/content/'.date('Y-m-d');
  $file_path = public_path($file_relative_path);
  if (!is_dir($file_path)){
  mkdir($file_path);
  }
  $thumbnail_file_path = $file_path . '/thumbnail-'.$file_name;
  $image = Image::make($photo)->resize(200, null, function ($constraint) {$constraint->aspectRatio();})->save($thumbnail_file_path);
  $file_path .= '/'.$file_name;
  $image = Image::make($photo)->save($file_path);
 
 echo ‘上传成功!';
 }
}

后端处理主要思想:首先通过Validator类库来检验当前上传上来的文件是否符合要求,如果符合要求,就可以对图片进行处理了;处理的时候我是先把要保存图片的相对地址给拼接好,然后通过laravel里面的public_path函数得出绝对的local地址;再去判断该文件夹是否存在,如果不存在那就创建该文件夹。创建好文件夹后我们就应该对上传上来的图片进行进一步处理了,比如我这里需要制作它的缩略图,并且保证图片横纵比,如果有其他的要求,可以前往Intervention Image类库自行查看怎么制作。

以上这篇laravel实现上传图片,并且制作缩略图,按照日期存放的代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
关于文本留言本的分页代码
Oct 09 PHP
遍历指定目录下的所有目录和文件的php代码
Nov 27 PHP
php启动时候提示PHP startup的解决方法
May 07 PHP
PHP-Fcgi下PHP的执行时间设置方法
Aug 02 PHP
9段PHP实用功能的代码推荐
Oct 14 PHP
PHP中创建图像并绘制文字的例子
Nov 19 PHP
codeigniter实现get分页的方法
Jul 10 PHP
PHP实现linux命令tail -f
Feb 22 PHP
Yii针对添加行的增删改查操作示例
Oct 18 PHP
Yii2使用$this-&gt;context获取当前的Module、Controller(控制器)、Action等
Mar 29 PHP
swoole_process实现进程池的方法示例
Oct 29 PHP
关于PHP中interface的用处详解
Jul 26 PHP
修改Laravel自带的认证系统的User类的命名空间的步骤
Oct 15 #PHP
解决Laravel自定义类引入和命名空间的问题
Oct 15 #PHP
laravel 如何实现引入自己的函数或类库
Oct 15 #PHP
Laravel 类和接口注入相关的代码
Oct 15 #PHP
在PHP中实现使用Guzzle执行POST和GET请求
Oct 15 #PHP
在Laravel中使用GuzzleHttp调用第三方服务的API接口代码
Oct 15 #PHP
解决在laravel中auth建立时候遇到的问题
Oct 15 #PHP
You might like
成为好程序员必须避免的5个坏习惯
2014/07/04 PHP
PHP 的比较运算与逻辑运算详解
2016/05/12 PHP
php自定义时间转换函数示例
2016/12/07 PHP
关于Curl在Swoole协程中的解决方案详析
2019/09/12 PHP
PHP 进程池与轮询调度算法实现多任务的示例代码
2019/11/26 PHP
php模拟post提交请求调用接口示例解析
2020/08/07 PHP
11个用于提高排版水平的基于jquery的文字效果插件
2012/09/14 Javascript
通过jQuery源码学习javascript(二)
2012/12/27 Javascript
在JavaScript并非所有的一切都是对象
2013/04/11 Javascript
利用jq让你的div居中的好方法分享
2013/11/21 Javascript
jquery带有索引按钮且自动轮播切换特效代码分享
2015/09/15 Javascript
使用Javascript判断浏览器终端设备(PC、IOS(iphone)、Android)
2017/01/04 Javascript
javascript阻止事件冒泡和浏览器的默认行为
2017/01/21 Javascript
jQuery插件form-validation-engine正则表达式操作示例
2017/02/09 Javascript
浅析JavaScript中的特殊数据类型
2017/12/15 Javascript
推荐10款扩展Web表单的JS插件
2017/12/25 Javascript
Vue cli+mui 区域滚动的实例代码
2018/01/25 Javascript
Vue动态路由缓存不相互影响的解决办法
2019/02/19 Javascript
浅谈Node 异步IO和事件循环
2019/05/05 Javascript
在Vue里如何把网页的数据导出到Excel的方法
2020/09/30 Javascript
[02:51]DOTA2英雄基础教程 风暴之灵
2013/12/23 DOTA
[00:15]天涯墨客终极技能展示
2018/08/25 DOTA
Python多进程并发与多线程并发编程实例总结
2018/02/08 Python
Python基于dom操作xml数据的方法示例
2018/05/12 Python
Python for循环中的陷阱详解
2018/07/13 Python
python KNN算法实现鸢尾花数据集分类
2019/10/24 Python
python+selenium自动化实战携带cookies模拟登陆微博
2021/01/19 Python
Office DEPOT法国官网:欧迪办公用品采购
2018/01/03 全球购物
Aquatalia官网:意大利著名鞋履品牌
2019/09/26 全球购物
你们项目是如何进行变更控制的
2015/08/26 面试题
《雾凇》教学反思
2014/02/17 职场文书
《美丽的小路》教学反思
2014/02/26 职场文书
保险经纪人求职信
2014/03/11 职场文书
安全生产一岗双责责任书
2014/07/28 职场文书
2014年个人售房协议书
2014/10/30 职场文书
CSS实现多个元素在盒子内两端对齐效果
2021/03/30 HTML / CSS