承接 apsonex/laravel-stock-image 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

apsonex/laravel-stock-image

最新稳定版本:1.0.3

Composer 安装命令:

composer require apsonex/laravel-stock-image

包简介

Stock Images

README 文档

README

Laravel Stock Image is a pluggable image search API tool that allows you to query stock images from various providers like Unsplash, Pexels, Pixabay, and also generate placeholder images dynamically.

🚀 Features

  • Supports multiple providers: Unsplash, Pexels, Pixabay, Placeholder
  • Custom API keys per request or config
  • Smart keyword fallback mechanism
  • Random image selection and provider rotation
  • Easy Laravel integration with route and controller
  • Fully testable and extendable architecture

📦 Installation

composer require apsonex/laravel-stock-image

If you're using Laravel 10+, package auto-discovery will register everything automatically.

⚙️ Configuration

Publish the configuration file if needed:

php artisan vendor:publish --tag=laravel-stock-image-config

This will create config/stock-image.php:

return [
    'route' => [
        'enable'     => true,
        'path'       => 'api/ai/tools/stock-images/search',
        'middleware' => [
            // middlewares
        ],
    ],
];

🔌 Routing

The package automatically registers this route when enabled in the config:

POST /stock-image-search

Payload Parameters

Key Type Description
keywords string Comma-separated keywords to search images (required)
random_result boolean Whether to return a random image from results
random_provider boolean Whether to pick a random provider
page int Which page to fetch from provider
cache boolean Whether to cache the result (default: false)
result_limit int Limit number of images result
provider_api_keys array Optional - Override API keys per provider (optional)
placeholder_size string Used only when fallback placeholder is returned e.g. 600x400
placeholder_text string Text to show in placeholder image e.g. Sample Text
placeholder_text_color string Color for placeholder text e.g. #000000
placeholder_bg_color string Background color for placeholder e.g. #cccccc

✅ Example Request (JSON)

POST to /api/ai/tools/stock-images/search

// result
{
  "keywords": "mountain, beach",
  "random_result": true,
  "random_provider": false,
  "page": 1,
  "cache": false,
  "result_limit": 10,
  "provider_api_keys": {
    "pexels": "<PEXELS_API_KEY>",
    "unsplash": "<UNSPLASH_API_KEY>",
    "pixabay": "<PIXABAY_API_KEY>"
  },
  "placeholder_text": "Placeholder Image",
  "placeholder_size": "600x400",
  "placeholder_bg_color": "cccccc",
  "placeholder_text_color": "333333"
}

🔄 Sample JSON Response

{
  "items": [
    {
      "image_url": "https://example.com/image.jpg",
      "image_description": "A stunning mountain landscape",
      "source": "unsplash"
    }
  ],
  "meta": {
    "page": 1,
    "per_page": 30,
    "count": 1
  },
  "status": "success"
}

🧪 Testing

You can run tests using Pest:

./vendor/bin/pest

Make sure to mock external APIs to avoid hitting rate limits.

🧠 License

MIT © Apsonex

统计信息

  • 总下载量: 37
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-06-15