I am trying to complete a button which allows someone to follow somone else. It is designed to be a social networking button. I could get the button to work whever the page is loaded which is highly undersirable but I cant make it work when the button is pressed.
I have really stuck on this, does anyone have any suggestions on what I can try to get it to work.
<?php
$followerid = intval($_SESSION['userID']);
$profileid = intval($row['id']);
if(isset($_POST['followbutton']) && $_POST['followbutton'] == 'true'){
if($profileid = $followerid) {
$errors['profileid'] = "This is a test error.";
}
if(!$errors){
//Validation of input vars passed, attempt to run query
//Force vars to be ints to be safe for query statement
$followerid = intval($_SESSION['userID']);
$profileid = intval($row['id']);
$query = "INSERT INTO `follow` (`user_id`, `follow_user_id`) VALUES ('{$profileid}', '{$followerid}')";
$result = mysql_query($query);
if (!$result)
{
$errors[] = "Query: {$query}<br>Error: " . mysql_error();
}
}
}
?>
I added but it has had no affect. Is there anyway I can strip it down or test in some way. I have tried using a debugger but I dont understand how they work.
<?php
$followerid = intval($_SESSION['userID']);
$profileid = intval($row['id']);
if(isset($_POST['followbutton']) && $_POST['followbutton'] == 'true'){
if($profileid = $followerid) {
$errors['profileid'] = "This is a test error.";
}
if(!$errors){
//Validation of input vars passed, attempt to run query
//Force vars to be ints to be safe for query statement
$followerid = intval($_SESSION['userID']);
$profileid = intval($row['id']);
$query = "INSERT INTO `follow` (`user_id`, `follow_user_id`) VALUES ('{$profileid}', '{$followerid}')";
$result = mysql_query($query);
if (!$result)
{
$errors[] = "Query: {$query}<br>Error: " . mysql_error();
}
}
}
?>
<?php if($errors['profileid']) print '<div class="invalid">' . $errors['profileid'] . ''; ?>
</div>
<div class="followbuttonbox">
<a href="<?php echo $_SERVER['PHP_SELF']; ?>?ID=<?php echo $profileid; ?>"><img src="/images/follow.png" id="followbutton" /></a>
<input type="hidden" id="followbutton" name="followbutton" value="true">
<submit button>
</form>
Is that all the code in your php file? If so, then you must add more html and make a valid form.
Anyway you can check for php errors setting this in the beginning of your file
Well, by add more html I mean that currently your page is incomplete and the form to get submit on button click you need a valid form.
In your case, something like this
What Ive noticed is that when I try to echo the two ID inside the isset code they do not publish on the screen. I have marked them with “THIS DOES NOT ECHO”.
Does help in anyway or explain what the issue is?
echo $profileid;
echo $followerid;
if(isset($_POST['followbutton']) && $_POST['followbutton'] == 'true'){
echo $profileid; THIS DOES NOT ECHO
echo $followerid; THIS DOES NOT ECHO
$query = "INSERT INTO `follow` (`user_id`, `follow_user_id`) VALUES ('{$profileid}', '{$followerid}')";
$result = mysql_query($query);
if (!$result)
{
$errors[] = "Query: {$query}<br>Error: " . mysql_error();
}
}
echo $profileid;
echo $followerid;
This line checks if followbutton is sent to script via post and if it’s value is ‘true’, if that criteria is not met, then code inside this if statement is not executed.
POST variable is passed to script via HTTP POST method, usually submitted via form, as in your script. In your script social button submits the form triggering the condition in if statement to be true and therefore running the code inside it. As I mentioned previously the problem was in your html code, preventing correctly submitting the form.
I would suggest put some effort into learning PHP, instead of just using scripts found on the web.