Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mewebstudio/captcha
Captcha for Laravel 5/6/7/8/9/10/11
https://github.com/mewebstudio/captcha
captcha laravel php security
Last synced: 4 days ago
JSON representation
Captcha for Laravel 5/6/7/8/9/10/11
- Host: GitHub
- URL: https://github.com/mewebstudio/captcha
- Owner: mewebstudio
- License: mit
- Created: 2013-03-27T00:01:06.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2024-09-10T05:47:20.000Z (3 months ago)
- Last Synced: 2024-10-29T15:03:35.600Z (about 1 month ago)
- Topics: captcha, laravel, php, security
- Language: PHP
- Homepage:
- Size: 1.21 MB
- Stars: 2,454
- Watchers: 60
- Forks: 453
- Open Issues: 131
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-laravel-framework - Captcha - Captcha for Laravel 5 - An anti-bot image captcha system. (Popular Packages)
- awesome-captcha - mewebstudio/captcha - CAPTCHA dla Laravel 5. (Biblioteki)
- laravel-awesome - Captcha - Captcha for Laravel - An anti-bot image captcha system. (Popular Packages)
- awesome-laravel - Captcha - An anti-bot image captcha system (Popular Packages)
- awesome-php-cn - mewebstudio/captcha - 图片验证码方案. (目录 / 图像 Imagery)
README
# Captcha for Laravel 10/11
[![Build Status](https://travis-ci.org/mewebstudio/captcha.svg?branch=master)](https://travis-ci.org/mewebstudio/captcha) [![Scrutinizer Code Quality](https://scrutinizer-ci.com/g/mewebstudio/captcha/badges/quality-score.png?b=master)](https://scrutinizer-ci.com/g/mewebstudio/captcha/?branch=master)
[![Latest Stable Version](https://poser.pugx.org/mews/captcha/v/stable.svg)](https://packagist.org/packages/mews/captcha)
[![Latest Unstable Version](https://poser.pugx.org/mews/captcha/v/unstable.svg)](https://packagist.org/packages/mews/captcha)
[![License](https://poser.pugx.org/mews/captcha/license.svg)](https://packagist.org/packages/mews/captcha)
[![Total Downloads](https://poser.pugx.org/mews/captcha/downloads.svg)](https://packagist.org/packages/mews/captcha)A simple [Laravel 5/6](http://www.laravel.com/) service provider for including the [Captcha for Laravel](https://github.com/mewebstudio/captcha).
for Laravel 4 [Captcha for Laravel Laravel 4](https://github.com/mewebstudio/captcha/tree/master-l4)
for Laravel 5 to 9 [Captcha for Laravel Laravel 4](https://github.com/mewebstudio/captcha/tree/master-l5-l9)
## Preview
![Preview](https://image.ibb.co/kZxMLm/image.png)- [Captcha for Laravel 5/6/7](#captcha-for-laravel-5-6-7)
* [Preview](#preview)
* [Installation](#installation)
* [Usage](#usage)
* [Configuration](#configuration)
+ [Custom settings:](#custom-settings)
+ [Disable validation:](#disable-validation)
* [Example Usage](#example-usage)
+ [Session Mode:](#session-mode)
+ [Stateless Mode:](#stateless-mode)
- [Return Image](#return-image)
- [Return URL](#return-url)
- [Return HTML](#return-html)
- [To use different configurations](#to-use-different-configurations)
* [Links](#links)
## InstallationThe Captcha Service Provider can be installed via [Composer](http://getcomposer.org) by requiring the
`mews/captcha` package and setting the `minimum-stability` to `dev` (required for Laravel 5) in your
project's `composer.json`.```json
{
"require": {
"laravel/framework": "5.0.*",
"mews/captcha": "~3.0"
},
"minimum-stability": "stable"
}
```or
Require this package with composer:
```
composer require mews/captcha
```Update your packages with ```composer update``` or install with ```composer install```.
In Windows, you'll need to include the GD2 DLL `php_gd2.dll` in php.ini. And you also need include `php_fileinfo.dll` and `php_mbstring.dll` to fit the requirements of `mews/captcha`'s dependencies.
## Usage
To use the Captcha Service Provider, you must register the provider when bootstrapping your Laravel application. There are
essentially two ways to do this.Find the `providers` key in `config/app.php` and register the Captcha Service Provider.
```php
'providers' => [
// ...
'Mews\Captcha\CaptchaServiceProvider',
]
```
for Laravel 5.1+
```php
'providers' => [
// ...
Mews\Captcha\CaptchaServiceProvider::class,
]
```Find the `aliases` key in `config/app.php`.
```php
'aliases' => [
// ...
'Captcha' => 'Mews\Captcha\Facades\Captcha',
]
```
for Laravel 5.1+
```php
'aliases' => [
// ...
'Captcha' => Mews\Captcha\Facades\Captcha::class,
]
```For Laravel 11 : you do not need to add the alias, it will be added automatically.
## Configuration
### Custom settings:
To use your own settings, publish config.```$ php artisan vendor:publish```
`config/captcha.php`
```php
return [
'default' => [
'length' => 5,
'width' => 120,
'height' => 36,
'quality' => 90,
'math' => true, //Enable Math Captcha
'expire' => 60, //Captcha expiration
],
// ...
];
```
### Disable validation:
To disable the captcha validation use `CAPTCHA_DISABLE` environment variable. e.g. **.env** config:```php
CAPTCHA_DISABLE=true
```## Example Usage
### Session Mode:
```php
// [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 'Incorrect!
';
} else {
echo 'Matched :)
';
}
}
$form = '';
$form .= '';
$form .= '' . captcha_img() . '
';
$form .= '';
$form .= 'Check
';
$form .= '';
return $form;
});
```
Detailed Example in Laravel way
view files
```html
//register.blade.php
@error('captcha')
{{ $message }}@enderror
```
controller files
```php
Validator::make($input, [
'name' => ['required', 'string', 'max:255'],
'email' => [
'required',
'string',
'email',
'max:255',
Rule::unique(User::class),
],
'password' => $this->passwordRules(),
'captcha' => 'required|captcha'
])->validate();
```
### Stateless Mode:
You get key and img from this url
`http://localhost/captcha/api/math`
and verify the captcha using this method:
```php
//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
}
```# Return Image
```php
captcha();
```
or
```php
Captcha::create();
```# Return URL
```php
captcha_src();
```
or
```
Captcha::src('default');
```# Return HTML
```php
captcha_img();
```
or
```php
Captcha::img();
```# To use different configurations
```php
captcha_img('flat');Captcha::img('inverse');
```
etc.Based on [Intervention Image](https://github.com/Intervention/image)
^_^
## Links
* [Intervention Image](https://github.com/Intervention/image)
* [L5 Captcha on Github](https://github.com/mewebstudio/captcha)
* [L5 Captcha on Packagist](https://packagist.org/packages/mews/captcha)
* [For L4 on Github](https://github.com/mewebstudio/captcha/tree/master-l4)
* [License](http://www.opensource.org/licenses/mit-license.php)
* [Laravel website](http://laravel.com)
* [Laravel Turkiye website](http://www.laravel.gen.tr)
* [mewebstudio](https://github.com/mewebstudio/captcha)