Jump to content

Recommended Posts

I wrote a viewer poll in php (not sure if this should go in the php section of here...) that on occasion is being hit by spammers.

 

Here's the code:

 

mysql_connect($DBhost,$DBuser,$DBpass) or die("Unable to connect to database"); 

@mysql_select_db("$DBName") or die("Unable to select database $DBName"); 

$ip=$_SERVER['REMOTE_ADDR']; 

$sqlquery = "INSERT INTO $db VALUES('$ip', '$_POST[q1]')";

$results = mysql_query($sqlquery);

if (empty($_POST[q1])) { 
Print "You must make a selection.  Please us your back button and select an answer"; 
}
else {

  if ($results){ 
    echo '<meta http-equiv=Refresh content=1;url="page.php?page=poll_results">';
  } 
  else{ 
    echo '<meta http-equiv=Refresh content=1;url="page.php?page=poll_oops">';
  } 
}
  mysql_close (); 

 

In essence, the code writes the users ip and the vote into the db.  It's supposed to keep the user from not selecting an answer (this part:  if (empty($_POST[q1])) {

Print "You must make a selection.  Please us your back button and select an answer";

} )  but it doesn't keep the spammers from hitting the page (I'm assuming looking for a bad email form to use for spam...).  How can I re-write this to ensure that a vote needs to be made?

 

Thanks.

 

Brian

Link to comment
https://forums.phpfreaks.com/topic/132664-solved-form-spam/
Share on other sites

If that code is your page structure.. it's inserting the vote before doing any validation.  Unless I'm missing part of your question, try structuring it like this.

 

<?php
  $ip=$_SERVER['REMOTE_ADDR'];//remote ip

if (empty($_POST[q1])) {
Print "You must make a selection.  Please use your back button and select an answer";
}
else {

//Answer wasn't empty
  mysql_connect($DBhost,$DBuser,$DBpass) or die("Unable to connect to database");
  @mysql_select_db("$DBName") or die("Unable to select database $DBName");

  $sqlquery = "INSERT INTO $db VALUES('$ip', '$_POST[q1]')";
    $results = mysql_query($sqlquery);

  //query went through
  if ($results){
    echo '<meta http-equiv=Refresh content=1;url="page.php?page=poll_results">';
  }
  
  //query failed [or] answer was empty
  else{
    echo '<meta http-equiv=Refresh content=1;url="page.php?page=poll_oops">';
  }
}

mysql_close ();
?>

 

Also, you really should validate $_POST[q1] to ensure it contains only the values 1-4 or whatever you're looking for.

Link to comment
https://forums.phpfreaks.com/topic/132664-solved-form-spam/#findComment-692478
Share on other sites

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.