recaptcha php验证,Invisible reCAPTCHA 是reCAPTCHA v2(没有验证码)的改进版本

Invisible reCAPTCHA

68747470733a2f2f696d672e736869656c64732e696f2f62616467652f7068702d253345253344253230352e362d3838393242462e73766768747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f762f616c626572746368742f696e76697369626c652d7265636170746368612e73766768747470733a2f2f706f7365722e707567782e6f72672f616c626572746368742f696e76697369626c652d7265636170746368612f646f776e6c6f61647368747470733a2f2f6170692e7472617669732d63692e6f72672f616c626572746368742f696e76697369626c652d7265636170746368612e7376673f6272616e63683d6d6173746572

630371349d6a6f7d51de9718289c323e.png

Why Invisible reCAPTCHA?

Invisible reCAPTCHA is an improved version of reCAPTCHA v2(no captcha). In reCAPTCHA v2, users need to click the button: "I'm not a robot" to prove they are human. In invisible reCAPTCHA, there will be not embed a captcha box for users to click. It's totally invisible! Only the badge will show on the buttom of the page to hint users that your website is using this technology. (The badge could be hidden, but not suggested.)

Notice

The master branch doesn't support multi captchas feature, please use multi-forms branch if you need it. (Most of the time you are misusing recaptcha when you try to put multiple captchas in one page.)

Installation

composer require albertcht/invisible-recaptcha

Laravel 5

Setup

Add ServiceProvider to the providers array in app/config/app.php.

AlbertCht\InvisibleReCaptcha\InvisibleReCaptchaServiceProvider::class,

It also supports package discovery for Laravel 5.5.

Configuration

Before you set your config, remember to choose invisible reCAPTCHA while applying for keys. f5c4d39e61411a817699edbbc01e0239.png

Add INVISIBLE_RECAPTCHA_SITEKEY, INVISIBLE_RECAPTCHA_SECRETKEY to .env file.

// required

INVISIBLE_RECAPTCHA_SITEKEY={siteKey}

INVISIBLE_RECAPTCHA_SECRETKEY={secretKey}

// optional

INVISIBLE_RECAPTCHA_BADGEHIDE=false

INVISIBLE_RECAPTCHA_DATABADGE='bottomright'

INVISIBLE_RECAPTCHA_TIMEOUT=5

INVISIBLE_RECAPTCHA_DEBUG=false

There are three different captcha styles you can set: bottomright, bottomleft, inline

If you set INVISIBLE_RECAPTCHA_BADGEHIDE to true, you can hide the badge logo.

You can see the binding status of those catcha elements on browser console by setting INVISIBLE_RECAPTCHA_DEBUG as true.

Usage

Before you render the captcha, please keep those notices in mind:

render() or renderHTML() function needs to be called within a form element.

You have to ensure the type attribute of your submit button has to be submit.

There can only be one submit button in your form.

Display reCAPTCHA in Your View

{!! app('captcha')->render() !!}

// or you can use this in blade

@captcha

With custom language support:

{!! app('captcha')->render('en') !!}

// or you can use this in blade

@captcha('en')

Usage with Javascript frameworks like VueJS:

The render() process includes three distinct sections that can be rendered separately incase you're using the package with a framework like VueJS which throws console errors when

You can render the polyfill (do this somewhere like the head of your HTML:)

{!! app('captcha')->renderPolyfill() !!}

// Or with blade directive:

@captchaPolyfill

You can render the HTML using this following, this needs to be INSIDE your

tag:

{!! app('captcha')->renderCaptchaHTML() !!}

// Or with blade directive:

@captchaHTML

And you can render the neccessary

// The argument is optional.

{!! app('captcha')->renderFooterJS('en') !!}

// Or with blade directive:

@captchaScripts

// blade directive, with language support:

@captchaScripts('en')

Validation

Add 'g-recaptcha-response' => 'required|captcha' to rules array.

$validate = Validator::make(Input::all(), [

'g-recaptcha-response' => 'required|captcha'

]);

CodeIgniter 3.x

set in application/config/config.php :

$config['composer_autoload'] = TRUE;

add lines in application/config/config.php :

$config['recaptcha.sitekey'] = 'sitekey';

$config['recaptcha.secret'] = 'secretkey';

// optional

$config['recaptcha.options'] = [

'hideBadge' => false,

'dataBadge' => 'bottomright',

'timeout' => 5,

'debug' => false

];

In controller, use:

$data['captcha'] = new \AlbertCht\InvisibleReCaptcha\InvisibleReCaptcha(

$this->config->item('recaptcha.sitekey'),

$this->config->item('recaptcha.secret'),

$this->config->item('recaptcha.options'),

);

In view, in your form:

<?php echo $captcha->render(); ?>

Then back in your controller you can verify it:

$captcha->verifyResponse($_POST['g-recaptcha-response'], $_SERVER['REMOTE_ADDR']);

Without Laravel or CodeIgniter

Checkout example below:

<?php

require_once "vendor/autoload.php";

$siteKey = 'sitekey';

$secretKey = 'secretkey';

// optional

$options = [

'hideBadge' => false,

'dataBadge' => 'bottomright',

'timeout' => 5,

'debug' => false

];

$captcha = new \AlbertCht\InvisibleReCaptcha\InvisibleReCaptcha($siteKey, $secretKey, $options);

// you can override single option config like this

$captcha->setOption('debug', true);

if (!empty($_POST)) {

var_dump($captcha->verifyResponse($_POST['g-recaptcha-response'], $_SERVER['REMOTE_ADDR']));

exit();

}

?>

<?php echo $captcha->render(); ?>

Submit

Take Control of Submit Function

Use this function only when you need to take all control after clicking submit button. Recaptcha validation will not be triggered if you return false in this function.

_beforeSubmit = function(e) {

console.log('submit button clicked.');

// do other things before captcha validation

// e represents reference to original form submit event

// return true if you want to continue triggering captcha validation, otherwise return false

return false;

}

Customize Submit Function

If you want to customize your submit function, for example: doing something after click the submit button or changing your submit to ajax call, etc.

The only thing you need to do is to implement _submitEvent in javascript

_submitEvent = function() {

console.log('submit button clicked.');

// write your logic here

// submit your form

_submitForm();

}

Here's an example to use an ajax submit (using jquery selector)

_submitEvent = function() {

$.ajax({

type: "POST",

url: "{{route('message.send')}}",

data: {

"name": $("#name").val(),

"email": $("#email").val(),

"content": $("#content").val(),

// important! don't forget to send `g-recaptcha-response`

"g-recaptcha-response": $("#g-recaptcha-response").val()

},

dataType: "json",

success: function(data) {

// success logic

},

error: function(data) {

// error logic

}

});

};

Example Repository

This repo demonstrates how to use this package with ajax way.

Showcases

Credits

anhskohbo (the author of no-captcha package)

Support on Beerpay

Hey dude! Help me out for a couple of

🍻!

68747470733a2f2f626565727061792e696f2f616c626572746368742f696e76697369626c652d7265636170746368612f62616467652e7376673f7374796c653d626565722d73717561726568747470733a2f2f626565727061792e696f2f616c626572746368742f696e76697369626c652d7265636170746368612f6d616b652d776973682e7376673f7374796c653d666c61742d737175617265

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值