Skip to content

odorisioe/recaptcha

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

53 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Recaptcha

A reCAPTCHA Validator for Laravel 4.

Installation

Add the following line to the require section of composer.json:

{
    "require": {
        "greggilbert/recaptcha": "dev-master"
    }
}

Laravel 4 Setup

  1. Add Greggilbert\Recaptcha\RecaptchaServiceProvider to the service provider list in app/config/app.php.
  2. Run php artisan config:publish greggilbert/recaptcha.
  3. In app/config/packages/greggilbert/recaptcha/config.php, enter your reCAPTCHA public and private keys.
  • If you are not using the most recent version of reCAPTCHA, set version to 1.
  • If you are upgrading to v2 of reCAPTCHA, note that your keys from the previous version will not work, and you need to generate a new set in the reCAPTCHA admin.
  1. Add the following line into app/lang/[lang]/validation.php:
    "recaptcha" => 'The :attribute field is not correct.',

Usage

v2 (No Captcha)

  1. In your form, use Form::captcha() to echo out the markup.
  2. In your validation rules, add the following:
    $rules = array(
        // ...
        'g-recaptcha-response' => 'required|recaptcha',
    };

v1 (Legacy)

  1. In your form, use Form::captcha() to echo out the markup.
  2. In your validation rules, add the following:
    $rules = array(
        // ...
        'recaptcha_response_field' => 'required|recaptcha',
    };

It's also recommended to add required when validating.

Customization

reCAPTCHA allows for customization of the widget through a number of options, listed at the official documentation. You can configure the output of the captcha in several ways.

In the config.php, you can create an options array to set the default behavior. For example:

    // ...
    'options' => array(
		'theme' => 'white',
	),

would default all the reCAPTCHAs to the white theme. If you want to further customize, you can pass options through the Form option:

echo Form::captcha(array('theme' => 'blackglass'));

Alternatively, if you want to set a default template instead of the standard one, you can use the config:

    // ...
    'template' => 'customCaptcha',

or you can pass it in through the Form option:

echo Form::captcha(array('template' => 'customCaptcha'));

Options passed into Form::captcha will always supercede the configuration.

To change the language of the captcha, simply pass in a language as part of the options:

    'options' => array(
        'lang' => 'fr',
	),

You can do this both in the config and through the Form::captcha() call.

Limitation

Because of Google's way of displaying the reCAPTCHA, this package won't work if you load your form from an ajaxAJAX call. If you need to do it, you should use one of the alternate methods provided by Google.

About

reCAPTCHA Validator for Laravel 4

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • PHP 100.0%