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 htmlentities和htmlspecialchars 的区别
Aug 18 PHP
攻克CakePHP系列一 连接MySQL数据库
Oct 22 PHP
php判断终端是手机还是电脑访问网站的思路及代码
Apr 24 PHP
php中in_array函数用法探究
Nov 25 PHP
分享一则PHP定义函数代码
Feb 26 PHP
浅谈json_encode用法
Mar 05 PHP
PHP实现批量上传单个文件
Dec 29 PHP
PHP简单实现遍历目录下特定文件的方法小结
May 22 PHP
thinkPHP框架动态配置用法实例分析
Jun 14 PHP
PHP中一个有趣的preg_replace函数详解
Aug 15 PHP
解决在laravel中auth建立时候遇到的问题
Oct 15 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
PHP执行批量mysql语句的解决方法
2013/05/02 PHP
PHP版微信公众平台红包API
2015/04/02 PHP
php中yii框架实例用法
2020/12/22 PHP
基于javascript滚动图片具体实现
2013/11/18 Javascript
JavaScript的内存释放问题详解
2015/01/21 Javascript
jQuery选择器querySelector的使用指南
2015/01/23 Javascript
jQuery实现的指纹扫描效果实例(附演示与demo源码下载)
2016/01/26 Javascript
bootstrap3 兼容IE8浏览器!
2016/05/02 Javascript
JS简单实现无缝滚动效果实例
2016/08/24 Javascript
Jquery树插件zTree实现菜单树
2017/01/24 Javascript
vue-cli + sass 的正确打开方式图文详解
2017/10/27 Javascript
基于vue-cli创建的项目的目录结构及说明介绍
2017/11/23 Javascript
微信小程序的部署方法步骤
2018/09/04 Javascript
详解基于vue-cli3.0如何构建功能完善的前端架子
2018/10/09 Javascript
Js 利用正则表达式和replace函数获取string中所有被匹配到的文本(推荐)
2018/10/28 Javascript
Nuxt.js SSR与权限验证的实现
2018/11/21 Javascript
Vue源码中要const _toStr = Object.prototype.toString的原因分析
2018/12/09 Javascript
深入koa-bodyparser原理解析
2019/01/16 Javascript
JS实现集合的交集、补集、差集、去重运算示例【ES5与ES6写法】
2019/02/18 Javascript
tsconfig.json配置详解
2019/05/17 Javascript
基于jQuery实现挂号平台首页源码
2020/01/06 jQuery
JavaScript实现随机点名程序
2020/03/25 Javascript
Nuxt默认模板、默认布局和自定义错误页面的实现
2020/05/11 Javascript
Vue表单提交点击事件只允许点击一次的实例
2020/10/23 Javascript
Python脚本实现Web漏洞扫描工具
2016/10/25 Python
用Python实现随机森林算法的示例
2017/08/24 Python
Pandas之ReIndex重新索引的实现
2019/06/25 Python
python3+PyQt5 自定义窗口部件--使用窗口部件样式表的方法
2019/06/26 Python
Django 路由控制的实现
2019/07/17 Python
python装饰器练习题及答案
2019/11/01 Python
Python 程序报错崩溃后如何倒回到崩溃的位置(推荐)
2020/06/23 Python
成绩单家长评语大全
2014/04/16 职场文书
《第一次抱母亲》教学反思
2014/04/16 职场文书
六查六看六改心得体会
2014/10/14 职场文书
Mysql效率优化定位较低sql的两种方式
2021/05/26 MySQL
Oracle数据库事务的开启与结束详解
2022/06/25 Oracle