2013-05-03 2 views
0

У меня возникла проблема с той же страницей. Код проверки AJAX/JavaScript/PHP Captcha. Исходный код от http://www.phpcaptcha.org. Мы используем сторонний сайт для хранения всех наших данных формы в базе данных, которая редактируется несколькими людьми. В последнее время мы получаем тонну спама, поэтому мы пытаемся реализовать этот Captcha.return true для той же проверки страницы

Я порежу здесь погоню. Каждый раз код должен «возвращать false». Мне нужно, чтобы он «возвращал истину», если выполняются определенные условия. Код выглядит следующим образом:

<?php 
session_start(); // this MUST be called prior to any output including whitespaces and line breaks! 


$GLOBALS['DEBUG_MODE'] = 1; 
// CHANGE TO 0 TO TURN OFF DEBUG MODE 
// IN DEBUG MODE, ONLY THE CAPTCHA CODE IS VALIDATED, AND NO EMAIL IS SENT 
// EMAIL is edited out for school use 
if(isset($_POST['captcha_code'])) 
{ 
$a = array("error"=>0); 
print json_encode($a); 
} 
// Process the form, if it was submitted (Original Code called process_si_contact_form()) 
process_si_zoho1(); 

?> 
<html> 
<head> 

<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/prototype/1.7.0.0/prototype.js"></script> 


<script type="text/javascript"> 
//variables not part of original code 
    function reloadCaptcha() 
    { 
    //original code ElementId labled 'captcha_code' 
     document.getElementById('captcha').src ='securimage_show.php?sid=' + Math.random(); 
    } 

    var r, Submit; 
function processForm() 
{ 
    new Ajax.Request('<?php echo $_SERVER['PHP_SELF'] ?>', { 
     method: 'post', 
     //Original code did not state 'zoho1' 
     parameters: $('zoho1').serialize(), 
     onSuccess: function(transport) { 
     //Re-edited for school use. Not original code 
      try { 
       r = transport.responseText.evalJSON(); 
       Submit = r.submit 

       if (r.error == 0) { 
       alert('Congrats!'); 
       reloadCaptcha(); 


       } else { 

        alert("There was an error with your submission.\n\n" + r.message); 

       } 
      } catch(ex) { 

       alert("There was an error parsing the json"); 

      } 

     }, 
     onFailure: function(err) { 

      alert("Ajax request failed"); 
     } 

    }); 
return Submit; 
} 
} 
</script> 

process_si-zoho1() выглядит следующим образом:

<?php 
//Original code process called 'process_si_contact_form()) 
function process_si_zoho1() 
{ 
if ($_SERVER['REQUEST_METHOD'] == 'POST' && @$_POST['do'] == 'contact') { 
    // if the form has been submitted 

    foreach($_POST as $key => $value) { 
     if (!is_array($key)) { 
      // sanitize the input data 
      if ($key != '-------') $value = strip_tags($value); 
      $_POST[$key] = htmlspecialchars(stripslashes(trim($value))); 
     } 
    } 

    $captcha = $_POST['captcha_code']; // the user's entry for the captcha code 

    $errors = array(); // initialize empty error array 


    if (sizeof($errors) == 0) { 
     require_once dirname(__FILE__) . '/securimage.php'; 
     $securimage = new Securimage(); 

     if ($securimage->check($captcha) == false) { 
      $errors['captcha_error'] = 'Incorrect security code entered'; 

     } 
    } 

    if (sizeof($errors) == 0) { 
     // no errors, send the form 
     //Edited out mail function from original code 

//Changed JSON return array on successful validation to send new variable '$Submit' via serialized $entry 
     $Submit = true; 
     $entry = array('error' => 0, 'submit' => $Submit); 
     die(json_encode($entry)); 
    } else { 
     $errmsg = $captcha_error; 
     foreach($errors as $key => $error) { 
      // set up error messages to display with each field 
      $errmsg .= " - {$error}\n"; 
      $Submit = false; 
     } 
//Added $Submit to the return array 
     $return = array('error' => 1, 'message' => $errmsg, 'submit' => $Submit); 
     die(json_encode($return)); 
    } 


} // POST 
} // function process_si_zoho1() 


?> 

The 'processForm()' беги, когда кнопка нажата представить. Я уверен, что мне не хватает чего-то действительно простого здесь, я просто слишком вовлечен в это. Я очень ценю вашу помощь

Я знаю, что значение «Отправить» не определено до тех пор, пока не будет запущен PHP в AJAX.Request(), но я не могу понять, как определить переменную с самого начала. FYI, переменные 'r' и 'Submit' объявляются вне самой функции, так что это глобальные переменные. Если я попытаюсь вставить возврат в try/catch, он всегда даст мне ошибку в catch «Произошла ошибка при разборе json». Кроме того, с кодом, как сейчас, он всегда будет давать мне ту же ошибку и отправить форму в любом случае, так как значение Submit пусто. Даже если я определяю глобальную переменную «Отправить» как «ложную», она все равно возвращается, как будто она пустая.

Если в нижней части функции указано что-либо, кроме «return false», оно отправит форму без проверки Captcha. Я очень новичок во всем этом, но я занимаюсь исследованиями почти 2 недели в течение 4-8 часов в день и еще не нашел рабочий код. Возможно ли это? Я имею в виду, что другие веб-сайты используют такую ​​же проверку страниц и подчиняются сторонним базам данных?

Я могу предоставить больше кода при необходимости, но проблема, кажется, здесь. Если я не пытаюсь изменить возврат, Captcha проверяет штраф и код «if (r.error == 0)» выполняется отлично. Я даже добавил предупреждение, чтобы показать значение «Отправить» только для проверки передачи данных между функциями.

Я здесь нахожусь здесь. Буду признателен за любую помощь.

Спасибо,

Matt

Полный код (минус детали) выглядит следующим образом:

<?php 
session_start(); // this MUST be called prior to any output including whitespaces and line breaks! 


$GLOBALS['DEBUG_MODE'] = 1; 
// CHANGE TO 0 TO TURN OFF DEBUG MODE 
// IN DEBUG MODE, ONLY THE CAPTCHA CODE IS VALIDATED, AND NO EMAIL IS SENT 
// EMAIL is edited out for school use 

// Process the form, if it was submitted (Original Code called process_si_contact_form()) 
process_si_zoho1(); 

?> 
<html> 
<head> 

<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/prototype/1.7.0.0/prototype.js"></script> 


<script type="text/javascript"> 
//variables not part of original code 
    function reloadCaptcha() 
    { 
    //original code ElementId labled 'captcha_code' 
     document.getElementById('captcha').src = '/securimage_show.php?sid=' + Math.random(); 
    } 

    var r, Submit; 
function processForm() 
{ 
    new Ajax.Request('<?php echo $_SERVER['PHP_SELF'] ?>', { 
     method: 'post', 
     //Original code did not state 'zoho1' 
     parameters: $('zoho1').serialize(), 
     onSuccess: function(transport) { 
     //Re-edited for school use. Not original code 
      try { 
       r = transport.responseText.evalJSON(); 
       Submit = r.submit; 

       if (r.error == 0) { 
       alert('Congrats!'); 
       reloadCaptcha(); 


       } else { 

        alert("There was an error with your submission.\n\n" + r.message); 

       } 
      } catch(ex) { 

       alert("There was an error parsing the json"); 

      } 

     }, 
     onFailure: function(err) { 

      alert("Ajax request failed"); 
     } 

    }); 
return false; 
} 
} 
</script> 
</head> 
<body> 
    <form action="----------" id="zoho1" method="POST" name="leadForm" onsubmit="return processForm()"> 
     <input name="----------" type="hidden" value="----------" /> 
     <input name="----------" type="hidden" value="----------" /> 
     <input name="----------" type="hidden" value="----------" /> 
     <input name="----------" type="hidden" value="----------" /> 
     <input name="----------" type="hidden" value="----------" /> 
     <input name="----------" type="hidden" value="----------" /> 
     <input type="hidden" name="do" value="contact" /><br /> 
     <p> 
      <label for="First Name">First Name</label><br /> 
       <input class="required" maxlength="40" name="First Name" type="text" /></p> 
     <p> 
      <label for="Last Name">Last Name</label><br /> 
       <input class="required" maxlength="80" name="Last Name" type="text" /></p> 
     <p> 
      <label email="" for="">Email</label><br /> 
       <input class="required validate-email" maxlength="100" name="Email" type="text" /></p> 
     <p> 
      <label for="Phone">Main Phone</label><br /> 
       <input class="required" maxlength="30" name="Phone" type="text" /></p> 
     <p> 
      <label for="Mobile">Mobile Phone</label><br /> 
       <input maxlength="30" name="Mobile" type="text" /></p> 
     <p> 
      <label for="State">State</label><br /> 
       <select class="required validate-selection" name="State"><option selected="selected" value="-None-">-None-</option><option value="AL">AL</option><option value="AK">AK</option><option value="AZ">AZ</option><option value="AR">AR</option><option value="CA">CA</option><option value="CO">CO</option><option value="CT">CT</option><option value="DE">DE</option><option value="DC">DC</option><option value="FL">FL</option><option value="HI">HI</option><option value="ID">ID</option><option value="IL">IL</option><option value="IN">IN</option><option value="IA">IA</option><option value="KS">KS</option><option value="KY">KY</option><option value="LA">LA</option><option value="ME">ME</option><option value="MD">MD</option><option value="MA">MA</option><option value="MI">MI</option><option value="MN">MN</option><option value="MS">MS</option><option value="MO">MO</option><option value="MT">MT</option><option value="NE">NE</option><option value="NV">NV</option><option value="NH">NH</option><option value="NJ">NJ</option><option value="NM">NM</option><option value="NY">NY</option><option value="NC">NC</option><option value="ND">ND</option><option value="OH">OH</option><option value="OK">OK</option><option value="OR">OR</option><option value="PA">PA</option><option value="RI">RI</option><option value="SC">SC</option><option value="SD">SD</option><option value="TN">TN</option><option value="TX">TX</option><option value="UT">UT</option><option value="VT">VT</option><option value="VA">VA</option><option value="WA">WA</option><option value="WV">WV</option><option value="WI">WI</option><option value="WY">WY</option><option value="GA">GA</option></select></p> 
<!--<div><label for="Mailing Zip">Mailing Zip</label><br /><input type="text" maxlength="30" name="Mailing Zip" /></div>--><!--<div><label for="Mailing Country">Mailing Country</label><br /><input type="text" maxlength="30" name="Mailing Country" /></div>--> 
     <p> 
      <label for="----------">----------</label><br /> 
       <select class="required validate-selection" name="----------"><option selected="selected" value="-None-">-None-</option><option value="----------">----------</option><option value="----------">----------</option><option value="----------">----------</option><option value="----------">----------</option><option value="----------">----------</option><option value="----------">----------</option><option value="----------">----------</option><option value="----------">----------</option></select></p> 
     <p> 
      <label for="-------">----------</label><br /> 
       <select class="required validate-selection" name="-------"><option selected="selected" value="-None-">-None-</option><option value="----------">----------</option><option value="----------">----------</option><option value="----------">----------</option><option value="----------">----------</option><option value="----------">----------</option><option value="----------">----------</option></select></p> 
     <p> 
      <label for="-------">------------</label><br /> 
       <select class="required validate-selection" name="-------"><option selected="selected" value="-None-">-None-</option><option value="----------">----------</option><option value="----------">----------</option><option value="----------">----------</option><option value="---------">-----------</option></select></p> 
     <p> 
      <label for="-------">Intended Degree</label><br /> 
       <select class="required validate-selection" name="-------"><option selected="selected" value="-None-">-None-</option><option value="--------------">-------------</option><option value="-------------">-------------</option><option value="-------------">--------------</option></select></p> 
     <p> 
      <label for="-------">How did you hear about TTU?</label><br /> 
       <textarea class="required" height="250" maxlength="1000" name="-------" width="250"></textarea></p> 
     <p> 
      <label for="Description">Comments</label><br /> 
       <textarea height="250" maxlength="1000" name="Description" width="250"></textarea></p> 
        <img id="captcha" src="/securimage_show.php" alt="CAPTCHA IMAGE" /> 
        <input type="text" id="enterVerify" name="captcha_code" size="10" maxlength="6" /> 
        <input type="button" id="reload" name="Reload" value="Reload" onClick="reloadCaptcha()"> 
       <input class="form-button" name="save" type="submit" value="Submit" /> 
    </form> 
</body> 
</html> 
<?php 
//Original code process called 'process_si_contact_form()) 
function process_si_zoho1() 
{ 
if ($_SERVER['REQUEST_METHOD'] == 'POST' && @$_POST['do'] == 'contact') { 
    // if the form has been submitted 

    foreach($_POST as $key => $value) { 
     if (!is_array($key)) { 
      // sanitize the input data 
      if ($key != '-------') $value = strip_tags($value); 
      $_POST[$key] = htmlspecialchars(stripslashes(trim($value))); 
     } 
    } 

    $captcha = $_POST['captcha_code']; // the user's entry for the captcha code 

    $errors = array(); // initialize empty error array 


    if (sizeof($errors) == 0) { 
     require_once dirname(__FILE__) . '/securimage.php'; 
     $securimage = new Securimage(); 

     if ($securimage->check($captcha) == false) { 
      $errors['captcha_error'] = 'Incorrect security code entered'; 

     } 
    } 

    if (sizeof($errors) == 0) { 
     // no errors, send the form 
     //Edited out mail function from original code 

//Changed JSON return array on successful validation to send new variable '$Submit' via serialized $entry 
     $Submit = true; 
     $entry = array('error' => 0, 'submit' => $Submit); 
     die(json_encode($entry)); 
    } else { 
     $errmsg = $captcha_error; 
     foreach($errors as $key => $error) { 
      // set up error messages to display with each field 
      $errmsg .= " - {$error}\n"; 
      $Submit = false; 
     } 
//Added $Submit to the return array 
     $return = array('error' => 1, 'message' => $errmsg, 'submit' => $Submit); 
     die(json_encode($return)); 
    } 


} // POST 
} // function process_si_zoho1() 


?> 
+0

Вместо 'evalJSON()' Попробуйте использовать 'jQuery.parseJSON (json)'. Полные документы [здесь] (http://api.jquery.com/jQuery.parseJSON/). Дайте мне знать, если это сработает. – ROMMEL

+0

@ROMMEL Я, вероятно, что-то делаю неправильно, но это, похоже, не имело никакого эффекта. Теперь я получаю ошибку catch каждый раз. – Menelmor

+0

Там, где некоторые причины безопасности не использовать '$ _SERVER ['PHP_SELF']', но я не могу вспомнить сейчас. Добавьте возвращенный json и добавьте, что '$ ('zoho1'). Serialize()' содержит. – rekire

ответ

0

Спасибо за помощь. Я сделал еще несколько исследований, проблема была в JavaScript (моя наименее опытная часть кода). Я просто добавил к:

if (r.error == 0) 
document.forms['formname'].submit(); 

Спасибо за помощь, ребята! Я обязательно буду использовать этот форум еще раз!

0
<?php 

if(isset($_POST['captcha'])) 
{ 
    $a = array("error"=>0); 
    print json_encode($a); 
    exit(); 
} 
?> 

<html> 
<head> 
<script src="https://ajax.googleapis.com/ajax/libs/prototype/1.7.1.0/prototype.js" ></script> 
</head> 
<body onload="processForm()"> 




<form id="formtest" action="" method="POST"> 
<input type="text" name="captcha" value="1vfvrfr"> 
</form> 

<script> 

var r, Submit; 
function reloadCaptcha(){} 
function processForm() 
    { 
     new Ajax.Request('<?php echo $_SERVER['PHP_SELF'] ?>', { 
      method: 'post', 
      //Original code did not state 'zoho1' 
      parameters: $('formtest').serialize(), 
      onSuccess: function(transport) { 
      //Re-edited for school use. Not original code 
       try { 
        r = transport.responseText.evalJSON(); 
        Submit = r.submit 

        if (r.error == 0) { 
        alert('Congrats!'); 
        reloadCaptcha(); 


        } else { 

         alert("There was an error with your submission.\n\n" + r.message); 

        } 
       } catch(ex) { 

        alert("There was an error parsing the json"); 

       } 

      }, 
      onFailure: function(err) { 

       alert("Ajax request failed"); 
      } 

     }); 
    return Submit; 
    } 

</script> 
</body> 
</html> 
+0

Спасибо за помощь. У меня все еще есть проблемы. Теперь, похоже, он вообще не запускает скрипт. Я не получаю никаких предупреждений или чего-либо еще. Я попытался изменить свой сценарий в соответствии с вашим, но постоянно понял, что мне не хватает материала, поэтому я просто скопировал его и заменил «formtest», как вы сказали. Ничего не появляется, и он отправляет форму без проверки Captcha. – Menelmor

+0

Кроме того, я просто понял, что я не утверждал, что форма обрабатывается, как только загружается страница. Это самое первое. Он проверяет правильность этого способа, если нажата кнопка «Отправить». – Menelmor

+0

Вы включили библиотеку jquery? Я попытаюсь обработать его на прототипе – ROMMEL

Смежные вопросы