tuanna587/captcha

Laravel 5 & 6 验证码包

安装: 38

依赖者: 0

建议者: 0

安全性: 0

星标: 0

关注者: 0

分支: 450

类型:package

1.0.0 2023-07-04 15:52 UTC

This package is auto-updated.

Last update: 2024-09-04 18:32:10 UTC


README

Build Status Scrutinizer Code Quality Latest Stable Version Latest Unstable Version License Total Downloads

一个简单的Laravel 5/6服务提供者,用于包含Captcha for Laravel

适用于 Laravel 4 Captcha for Laravel Laravel 4

预览

Preview

安装

可以通过Composer安装Captcha服务提供者,在项目的composer.json中要求tuanna587/captcha包并将minimum-stability设置为dev(Laravel 5需要)。

{
  "require": {
    "laravel/framework": "5.0.*",
    "tuanna587/captcha": "~2.0"
  },
  "minimum-stability": "dev"
}

或者

使用composer安装此包

composer require tuanna587/captcha

使用composer update更新包或使用composer install安装。

在Windows中,您需要在php.ini中包含GD2 DLL php_gd2.dll,并且还需要包含php_fileinfo.dllphp_mbstring.dll以满足tuanna587/captcha依赖项的要求。

使用方法

要使用Captcha服务提供者,您必须在启动Laravel应用程序时注册提供者。有基本两种方式来做这件事。

config/app.php中找到providers键并注册Captcha服务提供者。

    'providers' => [
        // ...
        'Mews\Captcha\CaptchaServiceProvider',
    ]

对于Laravel 5.1+

    'providers' => [
        // ...
        Mews\Captcha\CaptchaServiceProvider::class,
    ]

config/app.php中找到aliases键。

    'aliases' => [
        // ...
        'Captcha' => 'Mews\Captcha\Facades\Captcha',
    ]

对于Laravel 5.1+

    'aliases' => [
        // ...
        'Captcha' => Mews\Captcha\Facades\Captcha::class,
    ]

配置

自定义设置

要使用自己的设置,发布配置。

$ php artisan vendor:publish

config/captcha.php

return [
    'default'   => [
        'length'    => 5,
        'width'     => 120,
        'height'    => 36,
        'quality'   => 90,
        'math'      => true,  //Enable Math Captcha
        'expire'    => 60,    //Captcha expiration
    ],
    // ...
];

禁用验证

要禁用验证码验证,使用环境变量CAPTCHA_DISABLE。例如,在.env配置文件中

CAPTCHA_DISABLE=true

示例用法

会话模式

    // [your site path]/Http/routes.php
    Route::any('captcha-test', function() {
        if (request()->getMethod() == 'POST') {
            $rules = ['captcha' => 'required|captcha'];
            $validator = validator()->make(request()->all(), $rules);
            if ($validator->fails()) {
                echo '<p style="color: #ff0000;">Incorrect!</p>';
            } else {
                echo '<p style="color: #00ff30;">Matched :)</p>';
            }
        }

        $form = '<form method="post" action="captcha-test">';
        $form .= '<input type="hidden" name="_token" value="' . csrf_token() . '">';
        $form .= '<p>' . captcha_img() . '</p>';
        $form .= '<p><input type="text" name="captcha"></p>';
        $form .= '<p><button type="submit" name="check">Check</button></p>';
        $form .= '</form>';
        return $form;
    });

无状态模式

您从这个URL获取key和img https:///captcha/api/math并使用此方法验证验证码

    //key is the one that you got from json response
    // fix validator
    // $rules = ['captcha' => 'required|captcha_api:'. request('key')];
    $rules = ['captcha' => 'required|captcha_api:'. request('key') . ',math'];
    $validator = validator()->make(request()->all(), $rules);
    if ($validator->fails()) {
        return response()->json([
            'message' => 'invalid captcha',
        ]);

    } else {
        //do the job
    }

返回图片

captcha();

或者

Captcha::create();

返回URL

captcha_src();

或者

Captcha::src('default');

返回HTML

captcha_img();

或者

Captcha::img();

使用不同的配置

captcha_img('flat');

Captcha::img('inverse');

等。

基于Intervention Image

^_^

链接