laravel实现上传图片,并且制作缩略图,按照日期存放的代码
2019-10-22 07:05
1296 查看
先上代码吧:
前端代码:
有很多小伙伴在做表单上传文件的时候没有注意表单的上传格式是什么,就可能导致上传文件、图片不成功!
<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实现上传图片,并且制作缩略图,按照日期存放的代码就是小编分享给大家的全部内容了,希望能给大家一个参考
您可能感兴趣的文章:
相关文章推荐
- laravel实现上传图片,并且制作缩略图,按照日期存放
- hchxxzx--》一个实现图片上传/产生缩略图/在上传图片上写字功能的完整页面代码
- C# 通过ASHX保存上传的图片并制作高质量的缩略图的代码
- 一个实现图片上传/产生缩略图/在上传图片上写字功能的完整页面代码
- php gd2 上传图片/文字水印/图片水印/等比例缩略图/实现代码
- ThinkPHP3.2.3 验证码 上传图片 制作缩略图 2.为自己的项目封装功能类 利用Page工具类实现分页效果 后台管理员登录系统实现
- php gd2 上传图片/文字水印/图片水印/等比例缩略图/实现代码
- php gd2 上传图片/文字水印/图片水印/等比例缩略图/实现代码
- C#.Net上传图片并生成缩略图的代码
- 实现上传图片之后显示预览javaScript代码
- ASP.NET(C#)实现一次性动态上传多张图片的代码(多个文件)
- 问题描述:制作上传头像缩略图,希望图片能够等比例剪切,类似豆瓣的头像上传功能
- 图片上传生成缩略图,并使用JQuery实现鼠标移动到缩略图显示相应的大图的例子
- jquery实现上传图片及图片大小验证、图片预览效果代码
- 上传图片并实现缩略图
- 上传图片并生成缩略图的ASP.NET2.0代码!
- 图片上传即时显示缩略图的js代码
- asp.net 自定义控件实现无刷新上传图片,立即显示缩略图,保存图片缩略图
- 利用PHP为大图片生成缩略图代码实现
- FCKEditor 2.63 上传图片时,可按日期生成文件名、生成缩略图、添加水印