Laravel+Intervention实现上传图片功能示例
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Laravel+Intervention实现上传图片功能示例,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1742字,纯文字阅读大概需要3分钟。
内容图文
![Laravel+Intervention实现上传图片功能示例](/upload/InfoBanner/zyjiaocheng/277/e3c63f8ac32a4c309ea69a5191f45999.jpg)
本文实例讲述了Laravel+Intervention实现上传图片功能。分享给大家供大家参考,具体如下:
问题
使用Laravel上传图片
解决
安装Intervention
根据这个链接来安装https://packagist.org/packages/intervention/image
使用Intervention
根据这个文档来进行使用http://image.intervention.io/getting_started/introduction
简单修改
使用下面的代码就能实现上传图片
Image::make(Input::file('photo'))->resize(300, 200)->save('foo.jpg');
由于Intervention保存的时候需要指定图片的保存的文件名,所以我写了一个工具类来生成随机文件名。
<?php /** * Created by PhpStorm. * User: Administrator * Date: 2017/5/2 0002 * Time: 17:34 */ namespace App\Libs; class UploadUtils { /** * 随机的文件名 * @param int $len 随机文件名的长度 * @return str 随机字符串 */ private static function randName($len = 10) { return substr(str_shuffle('abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ01234565789'), 0, $len); } /** * 创建文件上传到的路径 * @return str 文件上传的路径 */ private static function createDir() { $dir = env('UPLOADPATH') . date('Ymd', time()); if (is_dir($dir) || mkdir($dir, 0777, true)) { return $dir; } } /** * 获取上传文件的路径 * @return str 文件的全路径 */ public static function getUploadPath($ext = 'jpg') { return self::createDir() . '/' . self::randName() . '.' . $ext; } }
上传处理
//上传缩略图 if ($request->hasFile('thumb')) {//存在图片 $file = $request->file('thumb'); $path = UploadUtils::getUploadPath($file->guessExtension());//获取保存的文件路径 Image::make($file)->resize(env('THUMB_WIDTH'), env('THUMB_HEIGHT'))->save($path);//保存 ... #save database ... }
更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。
内容总结
以上是互联网集市为您收集整理的Laravel+Intervention实现上传图片功能示例全部内容,希望文章能够帮你解决Laravel+Intervention实现上传图片功能示例所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。