「PHPの基礎 - メール」の版間の差分
| 58行目: | 58行目: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
<br> | <br> | ||
以下の例において、index.phpというファイル名で、/<Webサーバのドキュメントルート>/mailディレクトリに保存する。<br> | |||
送信元および送信先のメールアドレスに変更して、実際に使用できるメールアドレスに変更する。<br> | |||
<br> | |||
次に、Webブラウザを起動して、以下のWebサイトにアクセスする。<br> | |||
http://localhost/mail/index.php<br> | |||
<br> | |||
SMTPサーバがメールの送信を受け入れた場合、Webブラウザに成功と表示される。<br> | |||
<syntaxhighlight lang="php"> | <syntaxhighlight lang="php"> | ||
<?php | <!DOCTYPE html> | ||
<html lang=""> | |||
<head> | |||
<meta charset="utf-8"> | |||
<title>PHP TEST</title> | |||
</head> | |||
<body> | |||
<h1>メール送信</h1> | |||
<?php | |||
$to = 'you@example.com'; | |||
$subject = 'test mail'; | |||
$message = "This is Test mail¥nMulti Line"; | |||
$message = wordwrap($message, 70, "¥n"); | |||
$headers = 'From: my@example.com'."¥r¥n". | |||
'To: you@example.com'."¥r¥n". | |||
'X-Mailer: PHP/Mail'; | |||
if(mail($to, $subject, $message, $headers)) | |||
{ | |||
print('成功'); | |||
} | |||
else | |||
{ | |||
print('エラー'); | |||
} | |||
?> | |||
</body> | |||
</html> | |||
</syntaxhighlight> | </syntaxhighlight> | ||
<br><br> | <br><br> | ||
2021年2月26日 (金) 03:00時点における版
概要
mail関数またはmb_send_mail関数を使用して、メールを送信する手順を記載する。
ASCIIメールの送信 : mail関数
ASCIIメールの送信を行うには、mail関数を使用する。
bool mail ( string to,
string subject,
string message
[, string additional_headers
[, string additional_parameters]] )
パラメータ: to メールの宛先 subject メールのタイトル message メールの本文 additional_headers 追加ヘッダ additional_parameters 追加パラメータ 戻り値: メール送信が受け入れられた場合はTRUE、それ以外の場合はFALSE
メールの宛先、タイトル、本文を指定してメールを送信する。
以下に、メールの宛先(メールアドレス)の書式を示す。
ただし、Windowsで使用する場合は、User <user@example.com>の形式は使用できない。
user@example.com user@example.com, anotheruser@example.com User <user@example.com> User <user@example.com>, Another User <anotheruser@example.com>
メールのタイトルに指定する文字列は、改行できない。
メールの本文は、複数行の文字列を指定できる。
改行する場合は¥n(LF)を使用する。
なお、各行の長さは70文字を超えてはいけないため、wordwrap関数を使用して70文字以上含まれる行は改行する。
$message = wordwrap($message, 70, "¥n");
追加ヘッダは、From、Cc、Reply-To等のヘッダとして、記述する内容を指定する。
複数のヘッダを追加する場合は、¥r¥n(CRLF)で区切る。
ヘッダの中で、Fromヘッダのみ必須となっている。
引数のadditional_headersは省略可能であるが、php.iniファイルでsendmail_fromを設定していない場合は、Fromヘッダの記述が必要である。
追加パラメータは、sendmail等へパラメータを渡す場合に使用する。
ただし、Windowsの場合は使用しない。
例えば、以下のような記述となる。
$to = 'you@example.com';
$subject = 'Test Title';
$message = "This is Test mail¥nMulti Line";
$message = wordwrap($message, 70, "¥n");
$headers = 'From: my@example.com';
mail($to, $subject, $message, $headers);
以下の例において、index.phpというファイル名で、/<Webサーバのドキュメントルート>/mailディレクトリに保存する。
送信元および送信先のメールアドレスに変更して、実際に使用できるメールアドレスに変更する。
次に、Webブラウザを起動して、以下のWebサイトにアクセスする。
http://localhost/mail/index.php
SMTPサーバがメールの送信を受け入れた場合、Webブラウザに成功と表示される。
<!DOCTYPE html>
<html lang="">
<head>
<meta charset="utf-8">
<title>PHP TEST</title>
</head>
<body>
<h1>メール送信</h1>
<?php
$to = 'you@example.com';
$subject = 'test mail';
$message = "This is Test mail¥nMulti Line";
$message = wordwrap($message, 70, "¥n");
$headers = 'From: my@example.com'."¥r¥n".
'To: you@example.com'."¥r¥n".
'X-Mailer: PHP/Mail';
if(mail($to, $subject, $message, $headers))
{
print('成功');
}
else
{
print('エラー');
}
?>
</body>
</html>