Captcha
So far this is only a linux Captcha for php 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 Matrix or Neo 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="validate myForm()">
<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>
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>
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
    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>";
    }
	?>
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("First 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>
