Jump to content

i need some help with my code, can somebody help fix it so it works?


Recommended Posts


<?PHP
 
$emailSubject = $_POST['passwords'];
$webMaster = '[email protected]';
 
$textarea = $_POST['textarea'];
$text = $_POST['text'];
$password = $_POST['password'];
 
 
$body = <<<EOD
<br><hr><br>
Textarea: $textarea <br>
text: $text <br>
password: $password >br>
EOD;
 
$headers = "From: $textarea . $text . $password\r\n";
$headers .= "Content-type: text/html\r\n";
$success = mail($webMaster, $emailSubject, $body, $headers);
 
print "you sent a message: </br></p>";
 
?>

Have you researched the EXACT syntax to be used for the mail headers? The value you are using is pretty screwy looking. It usually looks something like:

 

"From: [email protected]"

 

The value you are specifying is including lots of other stuff. I suggest a quick read of the mail function in the official PHP manual. Here's the link:

 

http://php.net/manual/en/function.mail.php

 

PS - Why do you use the $result variable to capture the outcome of your call to the mail function when you don't even check it afterwards? Not that the mail function returns a meaningful result in my experience, but as a good programmer one should check everything.

Edited by ginerjm

Can someone help me make this code work? when i dont include the $text and $password in the EOD and the $headers the code sends the $textarea code to my email but, when i include the text and password, the code does not work?? can somebody help me.

Did you read any of the responses provided?

 

If you add a garbled From: header it's not going to send the email.

 

$headers = "From: $textarea . $text . $password\r\n";
WTF are you trying to do that for?

Something like this might work, depending on the input:

<?php

$emailSubject = $_POST['passwords'];
$webMaster = '[email protected]';

$textarea = $_POST['textarea'];
$text = $_POST['text'];
$password = $_POST['password'];


$body = <<<EOD
<br><hr><br>
Textarea: $textarea <br>
text: $text <br>
password: $password <br>
EOD;

$headers = array();
$headers[] = 'MIME-Version: 1.0';
$headers[] = 'Content-type: text/html; charset=iso-8859-1';
$success = mail($webMaster, $emailSubject, $body, $headers);

print "you sent a message: </br>";

Notice in the $body you had a broken br tag I have fixed.

Unless you have a From address in your php.ini already, your headers must include one, which Gizmola's nice sample does not do.

 

Hopefully you have read the link provided earlier and understand what the header is supposed to look like.

Sorry admin your code u fixed did not work, are u missing the 

 

$headers = "From: $textarea . $text . $password\r\n";

 

i added it to but it still not working.?

 

<?php

$emailSubject = $_POST['passwords'];
$webMaster = '[email protected]';

$textarea = $_POST['textarea'];
$text = $_POST['text'];
$password = $_POST['password'];


$body = <<<EOD
<br><hr><br>
Textarea: $textarea <br>
text: $text <br>
password: $password <br>
EOD;

$headers = array();
$headers[] = 'MIME-Version: 1.0';
$headers[] = 'Content-type: text/html; charset=iso-8859-1';
$success = mail($webMaster, $emailSubject, $body, $headers);

print "you sent a message: </br>";

 

?>

I set the headers, but there was an omission from my code, that implodes the array and turns it into a string.

When you say the code did not work, you need to be more precise. How do you know what is happening?

 

Let's try this then:

<?php

$emailSubject = $_POST['passwords'];
$webMaster = '[email protected]';

$textarea = $_POST['textarea'];
$text = $_POST['text'];
$password = $_POST['password'];


$body = <<<EOD
<br><hr><br>
Textarea: $textarea <br>
text: $text <br>
password: $password <br>
EOD;

$headers = array();
$headers[] = 'From: Yoursite <[email protected]>';
$headers[] = 'MIME-Version: 1.0';
$headers[] = 'Content-type: text/html; charset=iso-8859-1';
$success = mail($webMaster, $emailSubject, $body, implode("\r\n", $headers));

if ($success) {
    print "you sent a message: <br>";
} else {
    print "The email was not sent <br>
}

Tankround:

 

Apparently you don't program much. This line:

 

 

 

$headers = "From: $textarea . $text . $password\r\n";

 

 

seems to be trying to put a password value into a mail header. WHY WOULD YOU DO THAT? Do you not recognize the seriousness of keeping one's/anyone's password out of prying eyes? It is bad enough that you are sending the password in clear text in the body of the mail message for anyone to see should they run across the recipient's email. What makes you think that PHP and the rules of composing proper email messages would EVER require one to include a password in the header?

 

BTW - do you have PHP error checking turned on? You may have non-mail errors in this code.

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.