php-gemini/generative-ai 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

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

php-gemini/generative-ai

最新稳定版本:v1.1.0

Composer 安装命令:

composer require php-gemini/generative-ai

包简介

Laravel-friendly PHP Package for Google Gemini Generative AI (including image & text)

README 文档

README

Packagist License: MIT PHP Version

A Laravel-friendly, lightweight PHP SDK to interact with Google Gemini Generative AI. Supports text generation, image input (vision), and is fully customizable for any PHP project.

✨ Features

  • ✅ Gemini text generation (prompt → response)
  • 🖼️ Image input support (base64 vision models)
  • 🔐 Full OAuth2 authentication (refresh token supported)
  • 🔧 Easy configuration via .env or constructor
  • 🧪 PHPUnit + Testbench testing support
  • 🎯 Laravel-ready (service provider + facade)
  • 📦 Composer installable
  • 📘 Full documentation included

🧪 Installation

Install via Composer:

composer require php-gemini/generative-ai

⚙️ Configuration

For Laravel users, publish the configuration file:

php artisan vendor:publish --provider="PhpGemini\GenerativeAI\Providers\GeminiServiceProvider"

Then update your .env file with your API Key:

GEMINI_API_KEY=your_actual_api_key
GEMINI_MODEL=gemini-1.5-flash

🔐 Using OAuth2? See the section below on generating and using refresh tokens instead.

🔐 OAuth2 Support

This SDK supports Google OAuth2 access via a refresh_token, client_id, and client_secret.

🔧 Generate Refresh Token

To generate your credentials securely, use our standalone command-line script: Zero-Asif/oauth2_refresh_token_generator

Follow the instructions in its README file. After running the script, add the output to your .env file:

GEMINI_OAUTH_CLIENT_ID=your_client_id
GEMINI_OAUTH_CLIENT_SECRET=your_client_secret
GEMINI_OAUTH_REFRESH_TOKEN=your_refresh_token

✅ The SDK will automatically use OAuth2 if an API key is not provided.

🚀 Usage

✅ In Laravel

use Gemini;

echo Gemini::generate("What's the future of AI?");

✅ In Plain PHP

Initialize with an API Key:

use PhpGemini\GenerativeAI\GeminiClient;

require 'vendor/autoload.php';

$gemini = new GeminiClient([
    'api_key' => 'your_api_key',
    'model' => 'gemini-1.5-flash',
]);

echo $gemini->generateContent("Tell me something interesting.");

Or initialize with OAuth2:

use PhpGemini\GenerativeAI\GeminiClient;
use PhpGemini\GenerativeAI\Services\OAuth2Service;

require 'vendor/autoload.php';

$oauth = new OAuth2Service([
    'client_id' => 'your_client_id',
    'client_secret' => 'your_client_secret',
    'refresh_token' => 'your_refresh_token',
]);

$gemini = new GeminiClient([
    'model' => 'gemini-1.5-flash',
    'oauth2' => $oauth
]);

echo $gemini->generateContent("Tell me something interesting.");

🖼️ Image Input (Vision Model)

$response = $gemini->generateContentWithImage('path/to/image.jpg', 'What’s in this image?');

⚠️ Note: Only supported for models that accept image input, like gemini-1.5-flash.

🧪 Testing (PHPUnit)

To run the test suite:

composer test

To use Testbench for testing within a Laravel application, first install it:

composer require --dev orchestra/testbench

🛠️ Roadmap

  • Text generation
  • Laravel integration
  • Image input (vision support)
  • OAuth2 integration (refresh token support)
  • Unit testing & mocking (PHPUnit + Testbench)
  • Streaming response support
  • Online documentation site (mkdocs)

📘 Documentation

Full documentation is available inside: docs/index.md

🤝 Contributing

Pull requests, issues, and feature suggestions are welcome!

git clone [https://github.com/php-gemini/generative-ai.git](https://github.com/php-gemini/generative-ai.git)
cd generative-ai
composer install

📄 License

This project is open-sourced under the MIT License.

🔗 Useful Links

🙋 Author

Zero-Asif (Asifuzzaman Asif)

✨ If this project helped you, please ⭐ the repo!

统计信息

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

GitHub 信息

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

其他信息

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