replace random image captcha with Google reCaptcha v2
This commit is contained in:
parent
24af2c2a21
commit
e5f89165cb
Binary file not shown.
|
Before Width: | Height: | Size: 1.8 KiB |
Binary file not shown.
|
Before Width: | Height: | Size: 1.2 KiB |
Binary file not shown.
|
Before Width: | Height: | Size: 1.1 KiB |
Binary file not shown.
|
Before Width: | Height: | Size: 3.6 KiB |
|
|
@ -1,52 +0,0 @@
|
||||||
<?php
|
|
||||||
session_start();
|
|
||||||
|
|
||||||
// make a string with all the characters that we
|
|
||||||
// want to use as the verification code
|
|
||||||
$alphanum = "ABCDEFGHJKMNPQRSTUVWXYZ23456789";
|
|
||||||
|
|
||||||
// generate the verication code
|
|
||||||
$rand = substr(str_shuffle($alphanum), 0, 5);
|
|
||||||
|
|
||||||
// choose one of four background images
|
|
||||||
$bgNum = rand(1, 4);
|
|
||||||
|
|
||||||
// create an image object using the chosen background
|
|
||||||
$image = imagecreatefromjpeg("background$bgNum.jpg");
|
|
||||||
|
|
||||||
$textColor = imagecolorallocate ($image, 0, 0, 0);
|
|
||||||
|
|
||||||
// write the code on the background image
|
|
||||||
imagestring ($image, 5, 5, 8, $rand, $textColor);
|
|
||||||
|
|
||||||
|
|
||||||
// create the hash for the verification code
|
|
||||||
// and put it in the session
|
|
||||||
$_SESSION['image_random_value'] = md5($rand);
|
|
||||||
|
|
||||||
// send several headers to make sure the image is not cached
|
|
||||||
// taken directly from the PHP Manual
|
|
||||||
|
|
||||||
// Date in the past
|
|
||||||
header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
|
|
||||||
|
|
||||||
// always modified
|
|
||||||
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");
|
|
||||||
|
|
||||||
// HTTP/1.1
|
|
||||||
header("Cache-Control: no-store, no-cache, must-revalidate");
|
|
||||||
header("Cache-Control: post-check=0, pre-check=0", false);
|
|
||||||
|
|
||||||
// HTTP/1.0
|
|
||||||
header("Pragma: no-cache");
|
|
||||||
|
|
||||||
|
|
||||||
// send the content type header so the image is displayed properly
|
|
||||||
header('Content-type: image/jpeg');
|
|
||||||
|
|
||||||
// send the image to the browser
|
|
||||||
imagejpeg($image);
|
|
||||||
|
|
||||||
// destroy the image to free up the memory
|
|
||||||
imagedestroy($image);
|
|
||||||
?>
|
|
||||||
31
sendform.php
31
sendform.php
|
|
@ -15,6 +15,10 @@
|
||||||
// $referals is a list of web site domains seperated by commas. Only requests originating from
|
// $referals is a list of web site domains seperated by commas. Only requests originating from
|
||||||
// these domains will be processed.
|
// these domains will be processed.
|
||||||
$referals = "domain.com";
|
$referals = "domain.com";
|
||||||
|
|
||||||
|
// Google reCaptcha v2 secret. Obtain your key from https://www.google.com/recaptcha/admin/create
|
||||||
|
// Enter your secret key below and be sure to integrate reCaptcha into your site with your site key.
|
||||||
|
$reCaptchaSecret = "";
|
||||||
|
|
||||||
// $excludeFields is a list of field names seperated by commas. Field names listed here will not
|
// $excludeFields is a list of field names seperated by commas. Field names listed here will not
|
||||||
// be included in the resulting email of this script.
|
// be included in the resulting email of this script.
|
||||||
|
|
@ -76,9 +80,30 @@
|
||||||
|
|
||||||
$theDomain = getdomain($_SERVER['HTTP_REFERER']);
|
$theDomain = getdomain($_SERVER['HTTP_REFERER']);
|
||||||
checkreferal();
|
checkreferal();
|
||||||
if(isset($_SESSION['image_random_value']) && strcasecmp(md5(strtoupper($_REQUEST['verification'])), $_SESSION['image_random_value']) != 0) {
|
|
||||||
die("Verification box did not match image");
|
// Google reCaptcha v2
|
||||||
}
|
if(isset($reCaptchaSecret)){
|
||||||
|
if(isset($_POST['g-recaptcha-response'])) $captcha=$_POST['g-recaptcha-response'];
|
||||||
|
else errormsg("Verification failed. Please try again.");
|
||||||
|
|
||||||
|
// post request to server
|
||||||
|
$url = 'https://www.google.com/recaptcha/api/siteverify?secret=' . urlencode($reCaptchaSecret) . '&response=' . urlencode($captcha);
|
||||||
|
$ch = curl_init();
|
||||||
|
|
||||||
|
curl_setopt($ch, CURLOPT_AUTOREFERER, TRUE);
|
||||||
|
curl_setopt($ch, CURLOPT_HEADER, 0);
|
||||||
|
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
|
||||||
|
curl_setopt($ch, CURLOPT_URL, $url);
|
||||||
|
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, TRUE);
|
||||||
|
|
||||||
|
$response = curl_exec($ch);
|
||||||
|
curl_close($ch);
|
||||||
|
|
||||||
|
$responseKeys = json_decode($response,true);
|
||||||
|
// should return JSON with success as true
|
||||||
|
if(!$responseKeys["success"]) errormsg("Verification failed. Please try again.");
|
||||||
|
}
|
||||||
|
|
||||||
checkrequired();
|
checkrequired();
|
||||||
if(!validemail($defaultFrom) && !isset($_POST['email'])) bademail($defaultFrom);
|
if(!validemail($defaultFrom) && !isset($_POST['email'])) bademail($defaultFrom);
|
||||||
fillrecipients();
|
fillrecipients();
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue