承接 hostkurd/flocms-captcha 相关项目开发

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

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

hostkurd/flocms-captcha

最新稳定版本:v1.0.0

Composer 安装命令:

composer require hostkurd/flocms-captcha

包简介

Image captcha package for FloCMS guest form verification.

README 文档

README

A lightweight, framework-friendly image captcha package for FloCMS.
Designed for secure guest form verification with minimal dependencies.

✨ Features

  • Simple image-based captcha (GD powered)
  • Fully customizable (size, fonts, characters, noise, etc.)
  • Session-based verification
  • Framework-agnostic (works outside FloCMS too)
  • PSR-4 autoloaded
  • Extensible renderer system (future support for other drivers)

📦 Installation

Install via Composer:

composer require hostkurd/flocms-captcha

Requirements

  • PHP >= 8.1
  • GD extension enabled (ext-gd)

🚀 Quick Start

1. Create captcha instance

use FloCMS\Captcha\CaptchaManager;

$captcha = new CaptchaManager();

2. Output captcha image

Create a simple endpoint:

// public/captcha.php

require dirname(__DIR__) . '/vendor/autoload.php';

use FloCMS\Captcha\CaptchaManager;

$captcha = new CaptchaManager();
$captcha->output();

3. Display in form

<img src="/captcha.php" alt="Captcha">
<input type="text" name="captcha" required>

4. Verify input

use FloCMS\Captcha\CaptchaManager;

$captcha = new CaptchaManager();

if (!$captcha->verify($_POST['captcha'] ?? null)) {
    die('Invalid captcha');
}

5. Clear after success

$captcha->clear();

⚙️ Configuration

You can override default settings by passing a config array:

$captcha = new CaptchaManager([
    'length' => 5,
    'width' => 200,
    'height' => 60,
]);

Default Configuration

return [
    'length' => 6,
    'width' => 180,
    'height' => 50,
    'font_size' => 24,
    'angle_min' => -15,
    'angle_max' => 15,
    'noise_lines' => 8,
    'session_key' => 'flocms_captcha',
    'characters' => 'ABCDEFGHJKLMNPQRSTUVWXYZ23456789',
    'case_sensitive' => false,
    'fonts' => [
        __DIR__ . '/../public/fonts/Acme.ttf',
        __DIR__ . '/../public/fonts/PlayfairDisplay.ttf',
        __DIR__ . '/../public/fonts/Ubuntu.ttf',
    ],
];

🧠 How It Works

  1. A random captcha string is generated
  2. The string is stored in session
  3. An image is rendered using GD
  4. User submits input
  5. Input is compared securely using hash_equals

🔐 Security Notes

  • Uses random_int() for cryptographically secure randomness
  • Uses hash_equals() to prevent timing attacks
  • Case-insensitive comparison by default (configurable)
  • Always use CSRF protection alongside captcha

🧩 Architecture

FloCMS\Captcha\
├── Captcha.php          // Logic (generate, store, verify)
├── CaptchaManager.php   // Facade / main API
├── Renderer\
│   ├── RendererInterface.php
│   └── GdRenderer.php   // Image rendering (GD)

🔄 Session Handling

By default, the package uses native PHP sessions:

$_SESSION['flocms_captcha']

Session is automatically started if not already active.

📁 Fonts

Fonts are included inside the package:

public/fonts/

You can replace or extend them:

$captcha = new CaptchaManager([
    'fonts' => [
        '/path/to/custom/font1.ttf',
        '/path/to/custom/font2.ttf',
    ]
]);

🔌 Extending (Custom Renderer)

You can create your own renderer by implementing:

FloCMS\Captcha\Renderer\RendererInterface

Example:

use FloCMS\Captcha\Renderer\RendererInterface;

class CustomRenderer implements RendererInterface
{
    public function render(string $text): void
    {
        // your rendering logic
    }
}

Then inject it:

$captcha = new CaptchaManager([], new CustomRenderer());

🧪 Example

Run the included example:

php -S localhost:8000 -t examples

Then open:

http://localhost:8000/basic.php

🏗️ Integration with FloCMS

Recommended usage:

  • Keep captcha as a separate package
  • Use alongside:
    • flocms-core (Session, CSRF, Validation)
  • Expose via route or public/captcha.php

❌ What NOT to Do

Avoid placing captcha inside:

public/themes/default/

Captcha is application logic, not a theme asset.

🛣️ Roadmap

  • Session adapter (FloCMS Session integration)
  • Multiple captcha drivers (SVG, math captcha, etc.)
  • API-based captcha (future support)
  • Rate limiting / anti-bruteforce
  • Audio captcha support

🤝 Contributing

Contributions are welcome.

  • Fork the repository
  • Create a feature branch
  • Submit a pull request

📄 License

MIT License

👤 Author

HostKurd

💡 Final Note

This package is intentionally lightweight and modular.
Use it as a drop-in captcha solution or extend it to fit your framework needs.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-03-19

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固