Difference between revisions of "Captcha"
|  (→No Captcha) | |||
| (32 intermediate revisions by 3 users not shown) | |||
| Line 1: | Line 1: | ||
| So far this is only a linux Captcha for php | So far this is only a linux Captcha for php | ||
| + | |||
| + | NOTE: If doing a wordpress captcha the easiest way is to use Really Simple CAPTCHA if the forms plugin supports it or using Recaptcha if supported by plugin. | ||
| + | |||
| + | == Grab The Captcha Files== | ||
| + | You can get the files [https://www.phpcaptcha.org/ here] if you don't have your own copy somewhere. | ||
| + | |||
| We are using Securimage that will allow customization of color but we dont offer that we will make the changes for it if need be. | We are using Securimage that will allow customization of color but we dont offer that we will make the changes for it if need be. | ||
| − | If in a  | + | == Grab The Html == | 
| + | |||
| + | If in a Website Builder pretty much we will be making a copy of the page into a .php file. | ||
| You may need to inspect element in google and copy the form code from there to insert it into the php file as it usually gets generated from java script, I usually copy the entire table script example below | You may need to inspect element in google and copy the form code from there to insert it into the php file as it usually gets generated from java script, I usually copy the entire table script example below | ||
| − | <syntaxhighlight lang="html4strict"> | + | <syntaxhighlight lang="html4strict" enclose="div"> | 
| <!--- I usually take out this div or at least take out the ID  ---> | <!--- I usually take out this div or at least take out the ID  ---> | ||
| − | <div id=" | + | <div id="something"> | 
| <table cellspacing="0" cellpadding="0" border="0" width="100%">   | <table cellspacing="0" cellpadding="0" border="0" width="100%">   | ||
| <tbody><tr> <td align="left" valign="top" width="45%"> </td> <td align="left" valign="top" width="10%"> | <tbody><tr> <td align="left" valign="top" width="45%"> </td> <td align="left" valign="top" width="10%"> | ||
| − | <form id=" | + | <!--- Even though it does not have it I usually add a name myForm to the form tag as an attribute ---> | 
| − | + | <form id="component form" class="custom_form" method="post" action="http://domain.com/verify.php" onsubmit="return validateForm()"> | |
| − | + | ||
| <div class="form-element-wrapper" id="name-id"> | <div class="form-element-wrapper" id="name-id"> | ||
| <label for="name" class="form-element-label" style="">Name</label> | <label for="name" class="form-element-label" style="">Name</label> | ||
| Line 49: | Line 57: | ||
| </syntaxhighlight> | </syntaxhighlight> | ||
| + | == Bring the Captcha up == | ||
| The next thing now is inputting the php captcha right before the submit button with the following code, Also need the require once for the script | The next thing now is inputting the php captcha right before the submit button with the following code, Also need the require once for the script | ||
| Line 60: | Line 69: | ||
| <?php echo Securimage::getCaptchaHtml() ?> | <?php echo Securimage::getCaptchaHtml() ?> | ||
| </div> | </div> | ||
| + | </syntaxhighlight> | ||
| + | |||
| + | == Verifying The Captcha == | ||
| + | [[#top|Top of Page]]<br /> | ||
| + | After this we will usually try and integrate with a previous verify form if they have one themselves or a thank you page if they have one. | ||
| + | Or we will just recopy the php page we just made and take out the form and replace it with the verifying information | ||
| + | |||
| + | <syntaxhighlight lang="php"> | ||
| + | <? | ||
| + | $fnam = $_POST['FirstName']; | ||
| + | $lnam = $_POST['LastName']; | ||
| + | $comment = $_POST['message']; | ||
| + | $subject = $_POST['subject']; | ||
| + | $number = $_POST['phone']; | ||
| + | //check for the email input name for case sensitivity | ||
| + | $email = $_POST['email']; | ||
| + | |||
| + | $image = new Securimage(); | ||
| + |     if ($image->check($_POST['captcha_code']) == true) { | ||
| + |       echo "Thank you For Contacting us"; | ||
| + | |||
| + | 	//formats the message | ||
| + |     $message = "First Name and Last Name: " . $fnam . " " . $lnam . "\n Email: " . $email . "\n Phone: " . $number . "\n Message: " . $comment; | ||
| + | |||
| + | |||
| + | |||
| + |     // message lines should not exceed 70 characters (PHP rule), so wrap it | ||
| + | |||
| + |     $message = wordwrap($message, 70); | ||
| + | |||
| + |     // send mail | ||
| + |     // make sure to change email to a valid email | ||
| + | |||
| + |     mail("[email protected]",$subject,$message,"From: $from\n"); | ||
| + |     } else { | ||
| + |       echo "Sorry, wrong code.<br />"; | ||
| + | 	  echo "To go back <a href='http://domain.com/contact-us.php'>click here</a>"; | ||
| + |     } | ||
| + | 	?> | ||
| + | </syntaxhighlight> | ||
| + | |||
| + | == Form Validation == | ||
| + | After you make sure that the captcha itself and email is sucessfully working with the captcha working correctly its on to field validation if required This is the main reason you need to name the form to something so javascript can check it out. The following code is usually the base of most validations and can always be added to as well. I usually throw it near the top of the header. | ||
| + | |||
| + | <syntaxhighlight lang="javascript"> | ||
| + | <script> | ||
| + | function validateForm() { | ||
| + |     //make sure the form has the name of myForm | ||
| + |     var x = document.forms["myForm"]["FirstName"].value; | ||
| + | 	var y = document.forms["myForm"]["LastName"].value; | ||
| + | 	//check case sensitive email  in the name | ||
| + | 	var z = document.forms["myForm"]["email"].value; | ||
| + | 	var atpos = z.indexOf("@"); | ||
| + |     var dotpos = z.lastIndexOf("."); | ||
| + |     if (x == null || x == "") { | ||
| + |         alert("First name must be filled out"); | ||
| + |         return false; | ||
| + |     } | ||
| + | 	else if (y==null || y=="") { | ||
| + | 		alert("Last name must be filled out"); | ||
| + | 		return false; | ||
| + | 	} | ||
| + | 	else if (atpos< 1 || dotpos<atpos+2 || dotpos+2>=z.length) { | ||
| + |         alert("Not a valid e-mail address"); | ||
| + |         return false; | ||
| + | 	} | ||
| + | } | ||
| + | </script> | ||
| + | </syntaxhighlight> | ||
| + | |||
| + | == Customization == | ||
| + | [[#top|Top of Page]]<br /> | ||
| + | The next thing would be customization, You can change it to a mathematical captcha or keep it as text, you can also change the lines below between 300 to 320 in the securimage.php file, the one for Mathematics would be line 542 | ||
| + | |||
| + | <syntaxhighlight lang="php"> | ||
| + |  public $image_bg_color = '#0044FF'; | ||
| + | |||
| + |     /** | ||
| + |      * The color of the captcha text | ||
| + |      * @var Securimage_Color | ||
| + |      */ | ||
| + |     public $text_color     = '#00aa00'; | ||
| + | |||
| + |     /** | ||
| + |      * The color of the lines over the captcha | ||
| + |      * @var Securimage_Color | ||
| + |      */ | ||
| + |     public $line_color     = '#707070'; | ||
| + | |||
| + |     /** | ||
| + |      * The color of the noise that is drawn | ||
| + |      * @var Securimage_Color | ||
| + |      */ | ||
| + |     public $noise_color    = '#707070'; | ||
| + | </syntaxhighlight> | ||
| + | |||
| + | == Redirect or Rename == | ||
| + | |||
| + | Pretty much everything from here is really finished except either renaming the files and links necessary if its a custom page, or if its a website builder account all you need to do is the redirect for the contact-us.html page. The htaccess file below | ||
| + | |||
| + | <syntaxhighlight lang="apache"> | ||
| + | Redirect 301 /contact-us.html /contact-us.php | ||
| + | </syntaxhighlight> | ||
| + | |||
| + | == One Possibly Perl Method == | ||
| + | http://captchas.net/sample/perl/ | ||
| + | |||
| + | == No Captcha == | ||
| + | |||
| + | |||
| + | This is googles new Captcha for websites. This just requires a different kind of verification below is the javascript for the form page. Also in rare instances there may be a wordpress theme so horrible and unkempt that you may need to look for the head tag yourself through their files as they do not have a header.php file. | ||
| + | <syntaxhighlight lang="html4strict"> | ||
| + | <script src="https://www.google.com/recaptcha/api.js"></script> | ||
| + | </syntaxhighlight> | ||
| + | This is the Div to put near the submit button or depending on the style of your form. | ||
| + | <syntaxhighlight lang="html4strict">   | ||
| + | <div class="g-recaptcha" data-sitekey="your-site-key" data-theme="ifyouwantone" ></div> | ||
| + | </syntaxhighlight> | ||
| + | This is the verification in php whether its on the same page or goes to a separate file. | ||
| + | <syntaxhighlight lang="php"> | ||
| + | <?php | ||
| + | $secret="your-secret-key"; | ||
| + | $response=$_POST["g-recaptcha-response"]; | ||
| + | $verify=file_get_contents("https://www.google.com/recaptcha/api/siteverify?secret={$secret}&response={$response}"); | ||
| + | $captcha_success=json_decode($verify); | ||
| + | |||
| + | if ($captcha_success->success==false) { | ||
| + | 	echo "<p>Please try again <a href='https://www.knightsofprocrastination.ca/guildsignup.php'>Click here</a></p>"; | ||
| + | } | ||
| + | else if ($captcha_success->success==true) { | ||
| + | |||
| + |     // send mail | ||
| + |     mail("[email protected]",$subject,$message); | ||
| + | |||
| + | 	echo "<p>Thank you for Signing up.</p>"; | ||
| + | } | ||
| + | ?> | ||
| + | </syntaxhighlight> | ||
| + | |||
| + | |||
| + | == Javascript Validation == | ||
| + | |||
| + | If the site calls for JavaScript validation, simply place the following code in amongst the other validation checks. | ||
| + | |||
| + | <syntaxhighlight lang="javascript"> | ||
| + | var response = grecaptcha.getResponse(); | ||
| + | |||
| + | if(response.length == 0) { | ||
| + | alert("Cannot leave CAPTCHA empty."); | ||
| + | return false; | ||
| + | } | ||
| + | </syntaxhighlight> | ||
| + | |||
| + | == IMPORTANT NOTE == | ||
| + | |||
| + | For this no CAPTCHA system to work, allow_url_fopen must be enabled. | ||
| + | |||
| + | === Recaptchalib.php === | ||
| + | |||
| + | Nice quick access to the recaptcha php script that was made by google. | ||
| + | <syntaxhighlight lang="php"> | ||
| + | <?php | ||
| + | /** | ||
| + |  * This is a PHP library that handles calling reCAPTCHA. | ||
| + |  *    - Documentation and latest version | ||
| + |  *          https://developers.google.com/recaptcha/docs/php | ||
| + |  *    - Get a reCAPTCHA API Key | ||
| + |  *          https://www.google.com/recaptcha/admin/create | ||
| + |  *    - Discussion group | ||
| + |  *          http://groups.google.com/group/recaptcha | ||
| + |  * | ||
| + |  * @copyright Copyright (c) 2014, Google Inc. | ||
| + |  * @link      http://www.google.com/recaptcha | ||
| + |  * | ||
| + |  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||
| + |  * of this software and associated documentation files (the "Software"), to deal | ||
| + |  * in the Software without restriction, including without limitation the rights | ||
| + |  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||
| + |  * copies of the Software, and to permit persons to whom the Software is | ||
| + |  * furnished to do so, subject to the following conditions: | ||
| + |  * | ||
| + |  * The above copyright notice and this permission notice shall be included in | ||
| + |  * all copies or substantial portions of the Software. | ||
| + |  * | ||
| + |  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
| + |  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
| + |  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
| + |  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
| + |  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||
| + |  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||
| + |  * THE SOFTWARE. | ||
| + |  */ | ||
| + | /** | ||
| + |  * A ReCaptchaResponse is returned from checkAnswer(). | ||
| + |  */ | ||
| + | class ReCaptchaResponse | ||
| + | { | ||
| + |     public $success; | ||
| + |     public $errorCodes; | ||
| + | } | ||
| + | class ReCaptcha | ||
| + | { | ||
| + |     private static $_signupUrl = "https://www.google.com/recaptcha/admin"; | ||
| + |     private static $_siteVerifyUrl = | ||
| + |         "https://www.google.com/recaptcha/api/siteverify?"; | ||
| + |     private $_secret; | ||
| + |     private static $_version = "php_1.0"; | ||
| + |     /** | ||
| + |      * Constructor. | ||
| + |      * | ||
| + |      * @param string $secret shared secret between site and ReCAPTCHA server. | ||
| + |      */ | ||
| + |     function ReCaptcha($secret) | ||
| + |     { | ||
| + |         if ($secret == null || $secret == "") { | ||
| + |             die("To use reCAPTCHA you must get an API key from <a href='" | ||
| + |                 . self::$_signupUrl . "'>" . self::$_signupUrl . "</a>"); | ||
| + |         } | ||
| + |         $this->_secret=$secret; | ||
| + |     } | ||
| + |     /** | ||
| + |      * Encodes the given data into a query string format. | ||
| + |      * | ||
| + |      * @param array $data array of string elements to be encoded. | ||
| + |      * | ||
| + |      * @return string - encoded request. | ||
| + |      */ | ||
| + |     private function _encodeQS($data) | ||
| + |     { | ||
| + |         $req = ""; | ||
| + |         foreach ($data as $key => $value) { | ||
| + |             $req .= $key . '=' . urlencode(stripslashes($value)) . '&'; | ||
| + |         } | ||
| + |         // Cut the last '&' | ||
| + |         $req=substr($req, 0, strlen($req)-1); | ||
| + |         return $req; | ||
| + |     } | ||
| + |     /** | ||
| + |      * Submits an HTTP GET to a reCAPTCHA server. | ||
| + |      * | ||
| + |      * @param string $path url path to recaptcha server. | ||
| + |      * @param array  $data array of parameters to be sent. | ||
| + |      * | ||
| + |      * @return array response | ||
| + |      */ | ||
| + |     private function _submitHTTPGet($path, $data) | ||
| + |     { | ||
| + |         $req = $this->_encodeQS($data); | ||
| + |         $response = file_get_contents($path . $req); | ||
| + |         return $response; | ||
| + |     } | ||
| + |     /** | ||
| + |      * Calls the reCAPTCHA siteverify API to verify whether the user passes | ||
| + |      * CAPTCHA test. | ||
| + |      * | ||
| + |      * @param string $remoteIp   IP address of end user. | ||
| + |      * @param string $response   response string from recaptcha verification. | ||
| + |      * | ||
| + |      * @return ReCaptchaResponse | ||
| + |      */ | ||
| + |     public function verifyResponse($remoteIp, $response) | ||
| + |     { | ||
| + |         // Discard empty solution submissions | ||
| + |         if ($response == null || strlen($response) == 0) { | ||
| + |             $recaptchaResponse = new ReCaptchaResponse(); | ||
| + |             $recaptchaResponse->success = false; | ||
| + |             $recaptchaResponse->errorCodes = 'missing-input'; | ||
| + |             return $recaptchaResponse; | ||
| + |         } | ||
| + |         $getResponse = $this->_submitHttpGet( | ||
| + |             self::$_siteVerifyUrl, | ||
| + |             array ( | ||
| + |                 'secret' => $this->_secret, | ||
| + |                 'remoteip' => $remoteIp, | ||
| + |                 'v' => self::$_version, | ||
| + |                 'response' => $response | ||
| + |             ) | ||
| + |         ); | ||
| + |         $answers = json_decode($getResponse, true); | ||
| + |         $recaptchaResponse = new ReCaptchaResponse(); | ||
| + |         if (trim($answers ['success']) == true) { | ||
| + |             $recaptchaResponse->success = true; | ||
| + |         } else { | ||
| + |             $recaptchaResponse->success = false; | ||
| + |             $recaptchaResponse->errorCodes = $answers [error-codes]; | ||
| + |         } | ||
| + |         return $recaptchaResponse; | ||
| + |     } | ||
| + | } | ||
| + | ?> | ||
| </syntaxhighlight> | </syntaxhighlight> | ||
Latest revision as of 21:39, 22 December 2016
So far this is only a linux Captcha for php
NOTE: If doing a wordpress captcha the easiest way is to use Really Simple CAPTCHA if the forms plugin supports it or using Recaptcha if supported by plugin.
Contents
Grab The Captcha Files
You can get the files here if you don't have your own copy somewhere.
We are using Securimage that will allow customization of color but we dont offer that we will make the changes for it if need be.
Grab The Html
If in a Website Builder pretty much we will be making a copy of the page into a .php file.
You may need to inspect element in google and copy the form code from there to insert it into the php file as it usually gets generated from java script, I usually copy the entire table script example below
<!--- I usually take out this div or at least take out the ID  --->
<div id="something">
<table cellspacing="0" cellpadding="0" border="0" width="100%"> 
<tbody><tr> <td align="left" valign="top" width="45%"> </td> <td align="left" valign="top" width="10%">
<!--- Even though it does not have it I usually add a name myForm to the form tag as an attribute --->
<form id="component form" class="custom_form" method="post" action="http://domain.com/verify.php" onsubmit="return validateForm()">
<div class="form-element-wrapper" id="name-id">
<label for="name" class="form-element-label" style="">Name</label>
<table class="personName-large" cellpadding="0" cellspacing="0"><tbody>
<tr><td class="FirstName">
<!-- I personally Like to make the inputs spaced out so its easier to see, and also if anyone views source it will look better organized at least as well. -->
<input class="form-element form-element-size-full valid" type="text" name="name-FirstName" value="" maxlength="">
<label for="name-FirstName" class="personName-label" style="font-size:smaller;">First Name<span style="color:#cc0000;font-weight:normal" valign="top">*</span></label></td><td class="LastName">
<input class="form-element form-element-size-full" type="text" name="name-LastName" value="" maxlength=""><label for="name-LastName" class="personName-label" style="font-size:smaller;">
Last Name<span style="color:#cc0000;font-weight:normal" valign="top">*</span></label></td></tr></tbody></table></div><div class="form-element-wrapper" id="Email-id"><label for="Email" class="form-element-label" style="">Email<span style="color:#cc0000;font-weight:normal" valign="top">*</span></label>
<input class="form-element form-element-size-large" type="text" name="Email" value="" maxlength=""></div><div class="form-element-wrapper" id="phone-id">
<label for="phone" class="form-element-label" style="">
Phone number</label>
<input class="form-element form-element-size-large" type="text" name="phone" value="" maxlength="">
</div><div class="form-element-wrapper" id="subject-id"><label for="subject" class="form-element-label" style="">Subject</label>
<input class="form-element form-element-size-large" type="text" name="subject" value="" maxlength="">
</div><div class="form-element-wrapper" id="message-id"><label for="message" class="form-element-label" style="">Message</label>
<textarea rows="8" class="form-element form-element-size-large" name="message"></textarea>
</div><div class="form-element-wrapper" id="submit-id"><div style="text-align: left;">
<input type="submit" class="form-element" name="submit" value="Submit"></div></div> 
</form></td> <td align="left" valign="top" width="45%"> </td> </tr> </tbody></table></div>
Bring the Captcha up
The next thing now is inputting the php captcha right before the submit button with the following code, Also need the require once for the script
<!---This will be at the top of the form page and the verify.php --->
 <?
  require_once './securimage/securimage.php';
  ?>
<!---And as well the captcha put near the submit --->
<div>
<?php echo Securimage::getCaptchaHtml() ?>
</div>
Verifying The Captcha
Top of Page
After this we will usually try and integrate with a previous verify form if they have one themselves or a thank you page if they have one.
Or we will just recopy the php page we just made and take out the form and replace it with the verifying information
<?
$fnam = $_POST['FirstName'];
$lnam = $_POST['LastName'];
$comment = $_POST['message'];
$subject = $_POST['subject'];
$number = $_POST['phone'];
//check for the email input name for case sensitivity
$email = $_POST['email'];
$image = new Securimage();
    if ($image->check($_POST['captcha_code']) == true) {
      echo "Thank you For Contacting us";
    
	//formats the message
    $message = "First Name and Last Name: " . $fnam . " " . $lnam . "\n Email: " . $email . "\n Phone: " . $number . "\n Message: " . $comment;
	
    // message lines should not exceed 70 characters (PHP rule), so wrap it
    $message = wordwrap($message, 70);
    // send mail
    // make sure to change email to a valid email
    mail("[email protected]",$subject,$message,"From: $from\n");
    } else {
      echo "Sorry, wrong code.<br />";
	  echo "To go back <a href='http://domain.com/contact-us.php'>click here</a>";
    }
	?>
Form Validation
After you make sure that the captcha itself and email is sucessfully working with the captcha working correctly its on to field validation if required This is the main reason you need to name the form to something so javascript can check it out. The following code is usually the base of most validations and can always be added to as well. I usually throw it near the top of the header.
<script>
function validateForm() {
    //make sure the form has the name of myForm
    var x = document.forms["myForm"]["FirstName"].value;
	var y = document.forms["myForm"]["LastName"].value;
	//check case sensitive email  in the name
	var z = document.forms["myForm"]["email"].value;
	var atpos = z.indexOf("@");
    var dotpos = z.lastIndexOf(".");
    if (x == null || x == "") {
        alert("First name must be filled out");
        return false;
    }
	else if (y==null || y=="") {
		alert("Last name must be filled out");
		return false;
	}
	else if (atpos< 1 || dotpos<atpos+2 || dotpos+2>=z.length) {
        alert("Not a valid e-mail address");
        return false;
	}
}
</script>
Customization
Top of Page
The next thing would be customization, You can change it to a mathematical captcha or keep it as text, you can also change the lines below between 300 to 320 in the securimage.php file, the one for Mathematics would be line 542
 public $image_bg_color = '#0044FF';
    /**
     * The color of the captcha text
     * @var Securimage_Color
     */
    public $text_color     = '#00aa00';
    /**
     * The color of the lines over the captcha
     * @var Securimage_Color
     */
    public $line_color     = '#707070';
    /**
     * The color of the noise that is drawn
     * @var Securimage_Color
     */
    public $noise_color    = '#707070';
Redirect or Rename
Pretty much everything from here is really finished except either renaming the files and links necessary if its a custom page, or if its a website builder account all you need to do is the redirect for the contact-us.html page. The htaccess file below
Redirect 301 /contact-us.html /contact-us.php
One Possibly Perl Method
http://captchas.net/sample/perl/
No Captcha
This is googles new Captcha for websites. This just requires a different kind of verification below is the javascript for the form page. Also in rare instances there may be a wordpress theme so horrible and unkempt that you may need to look for the head tag yourself through their files as they do not have a header.php file.
<script src="https://www.google.com/recaptcha/api.js"></script>
This is the Div to put near the submit button or depending on the style of your form.
  
<div class="g-recaptcha" data-sitekey="your-site-key" data-theme="ifyouwantone" ></div>
This is the verification in php whether its on the same page or goes to a separate file.
<?php
$secret="your-secret-key";
$response=$_POST["g-recaptcha-response"];
$verify=file_get_contents("https://www.google.com/recaptcha/api/siteverify?secret={$secret}&response={$response}");
$captcha_success=json_decode($verify);
if ($captcha_success->success==false) {
	echo "<p>Please try again <a href='https://www.knightsofprocrastination.ca/guildsignup.php'>Click here</a></p>";
}
else if ($captcha_success->success==true) {
	
    // send mail
    mail("[email protected]",$subject,$message);
	
	echo "<p>Thank you for Signing up.</p>";
}
?>
Javascript Validation
If the site calls for JavaScript validation, simply place the following code in amongst the other validation checks.
var response = grecaptcha.getResponse();
if(response.length == 0) {
alert("Cannot leave CAPTCHA empty.");
return false;
}
IMPORTANT NOTE
For this no CAPTCHA system to work, allow_url_fopen must be enabled.
Recaptchalib.php
Nice quick access to the recaptcha php script that was made by google.
<?php
/**
 * This is a PHP library that handles calling reCAPTCHA.
 *    - Documentation and latest version
 *          https://developers.google.com/recaptcha/docs/php
 *    - Get a reCAPTCHA API Key
 *          https://www.google.com/recaptcha/admin/create
 *    - Discussion group
 *          http://groups.google.com/group/recaptcha
 *
 * @copyright Copyright (c) 2014, Google Inc.
 * @link      http://www.google.com/recaptcha
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */
/**
 * A ReCaptchaResponse is returned from checkAnswer().
 */
class ReCaptchaResponse
{
    public $success;
    public $errorCodes;
}
class ReCaptcha
{
    private static $_signupUrl = "https://www.google.com/recaptcha/admin";
    private static $_siteVerifyUrl =
        "https://www.google.com/recaptcha/api/siteverify?";
    private $_secret;
    private static $_version = "php_1.0";
    /**
     * Constructor.
     *
     * @param string $secret shared secret between site and ReCAPTCHA server.
     */
    function ReCaptcha($secret)
    {
        if ($secret == null || $secret == "") {
            die("To use reCAPTCHA you must get an API key from <a href='"
                . self::$_signupUrl . "'>" . self::$_signupUrl . "</a>");
        }
        $this->_secret=$secret;
    }
    /**
     * Encodes the given data into a query string format.
     *
     * @param array $data array of string elements to be encoded.
     *
     * @return string - encoded request.
     */
    private function _encodeQS($data)
    {
        $req = "";
        foreach ($data as $key => $value) {
            $req .= $key . '=' . urlencode(stripslashes($value)) . '&';
        }
        // Cut the last '&'
        $req=substr($req, 0, strlen($req)-1);
        return $req;
    }
    /**
     * Submits an HTTP GET to a reCAPTCHA server.
     *
     * @param string $path url path to recaptcha server.
     * @param array  $data array of parameters to be sent.
     *
     * @return array response
     */
    private function _submitHTTPGet($path, $data)
    {
        $req = $this->_encodeQS($data);
        $response = file_get_contents($path . $req);
        return $response;
    }
    /**
     * Calls the reCAPTCHA siteverify API to verify whether the user passes
     * CAPTCHA test.
     *
     * @param string $remoteIp   IP address of end user.
     * @param string $response   response string from recaptcha verification.
     *
     * @return ReCaptchaResponse
     */
    public function verifyResponse($remoteIp, $response)
    {
        // Discard empty solution submissions
        if ($response == null || strlen($response) == 0) {
            $recaptchaResponse = new ReCaptchaResponse();
            $recaptchaResponse->success = false;
            $recaptchaResponse->errorCodes = 'missing-input';
            return $recaptchaResponse;
        }
        $getResponse = $this->_submitHttpGet(
            self::$_siteVerifyUrl,
            array (
                'secret' => $this->_secret,
                'remoteip' => $remoteIp,
                'v' => self::$_version,
                'response' => $response
            )
        );
        $answers = json_decode($getResponse, true);
        $recaptchaResponse = new ReCaptchaResponse();
        if (trim($answers ['success']) == true) {
            $recaptchaResponse->success = true;
        } else {
            $recaptchaResponse->success = false;
            $recaptchaResponse->errorCodes = $answers [error-codes];
        }
        return $recaptchaResponse;
    }
}
?>
