Laravel实现图片上传接口以及图片压缩优化&测试

1. 创建 Laravel 项目

确保你已经安装了 Laravel 和相关依赖。创建一个新的 Laravel 项目:

bash 复制代码
composer create-project --prefer-dist laravel/laravel image-upload
cd image-upload

2. 设置数据库

编辑 .env 文件以连接到你的数据库,然后运行迁移:

bash 复制代码
php artisan migrate

3. 创建控制器

使用 Artisan 命令创建一个控制器:

bash 复制代码
php artisan make:controller ImageController --resource

4. 实现上传逻辑

打开 app/Http/Controllers/ImageController.php 并添加以下方法:

php 复制代码
<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use Illuminate\Support\Facades\Storage;
use Illuminate\Support\Facades\Validator;

class ImageController extends Controller
{
    /**
     * Store a newly created resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\JsonResponse
     */
    public function store(Request $request)
    {
        // 验证请求数据
        $validator = Validator::make($request->all(), [
            'image' => 'required|image|mimes:jpeg,png,jpg,gif,svg|max:2048',
        ]);

        if ($validator->fails()) {
            return response()->json($validator->errors(), 422);
        }

        // 保存图片到 storage/app/public/images 目录
        $path = $request->file('image')->store('public/images');

        // 返回响应
        return response()->json([
            'message' => 'Image uploaded successfully.',
            'path' => Storage::url($path),
        ]);
    }
}

5. 添加路由

routes/api.php 中添加路由:

php 复制代码
use App\Http\Controllers\ImageController;

Route::post('/images', [ImageController::class, 'store']);

6. 使用场景

  • 用户上传个人头像
  • 商家上传商品图片
  • 用户上传评论中的附件图片

7. 优化建议

7.1 文件存储位置
  • 云存储服务:使用 Amazon S3 或其他云存储服务来存储图片,以减轻服务器的存储压力。
  • 本地存储 :如果使用本地存储,考虑使用符号链接将 storage/app/public 映射到 public/storage,这样可以直接通过 HTTP 访问这些文件。你需要在 config/filesystems.php 文件中配置 public 存储盘。
7.2 图片处理
  • 调整大小和压缩:使用 Intervention Image 或者 Laravel 的内置功能来调整图片大小、压缩等,以减少存储空间占用和带宽消耗。
  • 多尺寸生成:根据不同的展示需求生成不同尺寸的图片版本。
7.3 安全性
  • 严格验证:对上传文件类型进行严格验证,防止恶意文件上传。
  • 直接写入文件 :使用 Storage::put() 方法直接从二进制流写入文件,避免客户端上传可能带来的安全风险。
7.4 性能
  • 缓存机制:在生产环境中使用缓存机制来提高访问速度。
  • CDN 加速:使用 CDN 来加速图片加载速度。
7.5 错误处理
  • 详细错误信息:增加更详细的错误处理逻辑,例如当文件上传失败时返回具体原因。

8. 配置符号链接

如果你选择使用本地存储,需要在项目根目录下执行以下命令来创建符号链接:

bash 复制代码
php artisan storage:link

9. 配置云存储

如果你选择使用云存储,比如 Amazon S3,则需要在 config/filesystems.php 中配置 s3 存储盘,并且在 ImageController 中修改存储路径和获取 URL 的方式。

10. 测试

你可以使用 Postman 或 curl 来测试你的 API。例如使用 curl:

bash 复制代码
curl -X POST http://localhost/api/images \
     -F "image=@/path/to/image.jpg" \
     -H "Content-Type: multipart/form-data"

以上就是基于 Laravel 框架实现图片上传接口的详细步骤。

相关推荐
林深时见鹿7498 小时前
使用k8s k3s kuboard 部署 php hyperf 框架
php
长城20248 小时前
从词源和输出生成等角度详细解析PHP中常用文件操作类函数
php·文件·函数·文件操作函数
长城20249 小时前
PHP如何使用JpGraph生成3D饼形图?
开发语言·php·jpgraph·3d饼形图
熬夜苦读学习16 小时前
Reactor 反应堆模式
运维·服务器·网络·网络协议·http·智能路由器·php
小森林816 小时前
分享一次Guzzlehttp上传批量图片优化的经历
后端·php
THMAIL16 小时前
大模型0基础开发入门与实践:第11章 进阶:LangChain与外部工具调用
开发语言·langchain·php
分享点2 天前
Laravel 使用阿里云OSS S3 协议文件上传
阿里云·php·laravel
苏琢玉2 天前
订单号老是撞车?我写了个通用 PHP ID 生成器
php·composer
BingoGo2 天前
PHP 测试框架 Pest v4 正式发布 革命性的浏览器测试体验
后端·php
搬码临时工2 天前
通过自定义域名访问内网的web服务和tcp应用:内网ip到局域网外域名访问过程
服务器·tcp/ip·php