|
Posted by d43m0n AT shaw DOT ca on 09/13/06 18:18
Tha RagMan wrote:
> I have a little program that created the following PHP script to
> handle a basic form and email the results. What it doesn't do and I
> can't get it to do is send a separate email with inputted results data
> to another email address without it showing in the "To" header of
> either msgs. Alternately I would like for it to do a BCC. I have tried
> a number edits to the script but nothing so far has worked. Could
> someone with more PHP knowledge then I give me the lines of code that
> will accomplish either the separate email without displaying both
> email addys or BCC? I would be very appreciative if you could lend a
> helping hand with my problem.
> Many Thanks
> Tha RagMan
>
> <?php
> @$rec_mailto = addslashes($_POST['rec_mailto']);
> @$rec_subject = addslashes($_POST['rec_subject']);
> @$rec_thanks = addslashes($_POST['rec_thanks']);
> @$Name = addslashes($_POST['Name']);
> @$Email = addslashes($_POST['Email']);
> @$Company = addslashes($_POST['Company']);
> @$Street = addslashes($_POST['Street']);
> @$City = addslashes($_POST['City']);
> @$State = addslashes($_POST['State']);
> @$Zip = addslashes($_POST['Zip']);
> @$Phone = addslashes($_POST['Phone']);
> @$Comments = addslashes($_POST['Comments']);
>
> // Validation
> //Sending Email to form owner
> $pfw_header = "From: $Email\n"
> . "Reply-To: $Email\n";
> $pfw_subject = "Response Form";
> $pfw_email_to = "me@myhost.com";
> $pfw_message = "rec_mailto: $rec_mailto\n"
> . "rec_subject: $rec_subject\n"
> . "rec_thanks: $rec_thanks\n"
> . "Name: $Name\n"
> . "Email: $Email\n"
> . "Company: $Company\n"
> . "Street: $Street\n"
> . "City: $City\n"
> . "State: $State\n"
> . "Zip: $Zip\n"
> . "Phone: $Phone\n"
> . "Comments: $Comments\n";
> @mail($pfw_email_to, $pfw_subject ,$pfw_message ,$pfw_header ) ;
>
> echo("<p align='center'><font face='Arial' size='3'
> color='#FF0000'>Thanks for your response ! ! !</font></p>");
> ?>
The code your using is a mess.
You don't need to use '@' when defining your variables, and you don't
need to use lengthy varaible definitions.
Try using plain text with singal quotes, varibles w/o double quotes,
and definitions with NO quotes.
You don't need to use '@' infront of a Mail Function, there is no
verbose messages from using that function, except with errors, and they
are rare, to none.
Here is some source code I wrote just now...
#!/usr/bin/php
/*
* Mail (List of Common Headers)
*
* These are most of the globally accepted headers accepted to and
from using SMTP and POP3/IMAP, including web applications, and desktop
applications.
*
* Apparently-To: Messages with many recipients sometimes have a long
list of headers of the form "Apparently-To: rth@bieberdorf.edu" (one
line per recipient). These headers are unusual in legitimate mail; they
are normally a sign of a mailing list, and in recent times mailing
lists have generally used software sophisticated enough not to generate
a giant pile of headers.
* Bcc: (stands for "Blind Carbon Copy") If you see this header on
incoming mail, something is wrong. It's used like Cc: (see below), but
does not appear in the headers. The idea is to be able to send copies
of email to persons who might not want to receive replies or to appear
in the headers. Blind carbon copies are popular with spammers, since it
confuses many inexperienced users to get email that doesn't appear to
be addressed to them.
* Cc: (stands for "Carbon Copy", which is meaningful if you remember
typewriters) This header is sort of an extension of "To:"; it specifies
additional recipients. The difference between "To:" and "Cc:" is
essentially connotative; some mailers also deal with them differently
in generating replies.
* Comments: This is a nonstandard, free-form header field. It's most
commonly seen in the form "Comments: Authenticated sender is
<rth@bieberdorf.edu>". A header like this is added by some mailers
(notably the popular freeware program Pegasus) to identify the sender;
however, it is often added by hand (with false information) by spammers
as well. Treat with caution.
* Content-Transfer-Encoding: This header relates to MIME, a standard
way of enclosing non-text content in email. It has no direct relevance
to the delivery of mail, but it affects how MIME-compliant mail
programs interpret the content of the message.
* Content-Type: Another MIME header, telling MIME-compliant mail
programs what type of content to expect in the message.
* Date: This header does exactly what you'd expect: It specifies a
date, normally the date the message was composed and sent. If this
header is omitted by the sender's computer, it might conceivably be
added by a mail server or even by some other machine along the route.
It shouldn't be treated as gospel truth; forgeries aside, there are an
awful lot of computers in the world with their clocks set wrong.
* Errors-To: Specifies an address for mailer-generated errors, like
"no such user" bounce messages, to go to (instead of the sender's
address). This is not a particularly common header, as the sender
usually wants to receive any errors at the sending address, which is
what most (essentially all) mail server software does by default.
* From (without colon) This is the "envelope From" discussed above.
* From: (with colon) This is the "message From:" discussed above.
* Message-Id: (also Message-id: or Message-ID:) The Message-Id is a
more-or-less unique identifier assigned to each message, usually by the
first mailserver it encounters. Conventionally, it is of the form
"gibberish@bieberdorf.edu", where the "gibberish" part could be
absolutely anything and the second part is the name of the machine that
assigned the ID. Sometimes, but not often, the "gibberish" includes the
sender's username. Any email in which the message ID is malformed
(e.g., an empty string or no @ sign), or in which the site in the
message ID isn't the real site of origin, is probably a forgery.
* In-Reply-To: A Usenet header that occasionally appears in mail,
the In-Reply-To: header gives the message ID of some previous message
which is being replied to. It is unusual for this header to appear
except in email directly related to Usenet; spammers have been known to
use it, probably in an attempt to evade filtration programs.
* Mime-Version: (also MIME-Version:) Yet another MIME header, this
one just specifying the version of the MIME protocol that was used by
the sender. Like the other MIME headers, this one is usually eminently
ignorable; most modern mail programs will do the right thing with it.
* Newsgroups: This header only appears in email that is connected
with Usenet---either email copies of Usenet postings, or email replies
to postings. In the first case, it specifies the newsgroup(s) to which
the message was posted; in the second, it specifies the newsgroup(s) in
which the message being replied to was posted. The semantics of this
header are the subject of a low-intensity holy war, which effectively
assures that both sets of semantics will be used indiscriminately for
the foreseeable future.
* Organization: A completely free-form header that normally contains
the name of the organization through which the sender of the message
has net access. The sender can generally control this header, and silly
entries like "Royal Society for Putting Things on Top of Other Things"
are commonplace.
* Priority: An essentially free-form header that assigns a priority
to the mail. Most software ignores it. It is often used by spammers,
usually in the form "Priority: urgent" (or something similar), in an
attempt to get their messages read.
* Received: Discussed in detail above.
* References: The References: header is rare in email except for
copies of Usenet postings. Its use on Usenet is to identify the
"upstream" posts to which a message is a response; when it appears in
email, it's usually just a copy of a Usenet header. It may also appear
in email responses to Usenet postings, giving the message ID of the
post being responded to as well as the references from that post.
* Reply-To: Specifies an address for replies to go to. Though this
header has many legitimate uses (perhaps your software mangles your
From: address and you want replies to go to a correct address), it is
also widely used by spammers to deflect criticism. Occasionally a naive
spammer will actually solicit responses by email and use the Reply-To:
header to collect them, but more often the Reply-To: address in junk
email is either invalid or an innocent victim.
* Sender: This header is unusual in email (X-Sender: is usually used
instead), but appears occasionally, especially in copies of Usenet
posts. It should identify the sender; in the case of Usenet posts, it
is a more reliable identifier than the From: line.
* Subject: A completely free-form field specified by the sender,
intended, of course, to describe the subject of the message.
* To: The "message To: "described above. Note that the To: header
need not contain the recipient's address!
* X-headers is the generic term for headers starting with a capital
X and a hyphen. The convention is that X-headers are nonstandard and
provided for information only, and that, conversely, any nonstandard
informative header should be given a name starting with "X-". This
convention is frequently violated.
* X-Confirm-Reading-To: This header requests an automated
confirmation notice when the message is received or read. It is
typically ignored; presumably some software acts on it.
* X-Distribution: In response to problems with spammers using his
software, the author of Pegasus Mail added this header. Any message
sent with Pegasus to a sufficiently large number of recipients has a
header added that says "X-Distribution: bulk". It is explicitly
intended as something for recipients to filter against.
* X-Errors-To: Like Errors-To:, this header specifies an address for
errors to be sent to. It is probably less widely obeyed.
* X-Mailer: (also X-mailer:) A freeform header field intended for
the mail software used by the sender to identify itself (as advertising
or whatever). Since much junk email is sent with mailers invented for
the purpose, this field can provide much useful fodder for filters.
* X-PMFLAGS: This is a header added by Pegasus Mail; its semantics
are nonobvious. It appears in any message sent with Pegasus, so it
doesn't obviously convey any information to the recipient that isn't
covered by the X-Mailer: header.
* X-Priority: Another priority field, used notably by Eudora to
assign a priority (which appears as a graphical notation on the
message).
* X-Sender: The usual email analogue to the Sender: header in Usenet
news, this header purportedly identifies the sender with greater
reliability than the From: header. In fact, it is nearly as easy to
forge, and should therefore be viewed with the same sort of suspicion
as the From: header.
* X-UIDL: This is a unique identifier used by the POP protocol for
retrieving mail from a server. It is normally added between the
recipient's mail server and the recipient's actual mail software; if
mail arrives at the mail server with an X-UIDL: header, it is probably
junk (there's no conceivable use for such a header, but for some
unknown reason many spammers add one).
*
* Apparently-To: Full Name <user@host.ext>\r\n
* Cc: Full Name <user@host.ext>\r\n
* Bcc: Full Name <user@host.ext>\r\n
* Date: Day-Of-Week, Month Day-Of-Month Year 24hour-time\n\r
* From: Full Name <user@host.ext>\r\n
* Subject: Message\n\r
* X-Mailer:\n\r
* \n\r
* <Your_Mesg/>
*/
<?php
// http://www.faqs.org/rfcs/rfc2822
// (Unix) \r && (Windows) \n
//$mailto = fopen('php://stdin', 'r');
//$subject = fopen('php://stdin', 'r');
//$message = 'Test';
$message = 'Hey, Dude, hoes it going?';
$header = NULL;
$header .= 'To: Full Name <user@host.ext>' . "\r\n";
$header .= 'Cc: Full Name <user@host.ext>' . "\r\n";
$header .= 'Bcc: Full Name <user@host.ext>' . "\r\n";
$header .= 'Date: ' . date(r) . "\r\n";
$header .= 'From: Full Name <user@host.ext>' . "\r\n";
$header .= 'Return-path: Full Name <user@host.ext>' . "\r\n";
$header .= 'Subject: Hello Daemon.' . "\r\n";
$header .= $message;
mail(NULL, NULL, NULL, $header, NULL);
print 'Message:' . "\n\n" . $header . "\n\n";
?>
[Back to original message]
|