質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

87.49%

mb_send_mailで、送信成功・失敗したらvalueの値を変換する

受付中

回答 3

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 3,860

score 16

前提・実現したいこと

メールフォームで、送信前のsubmitボタン表記は「送信する」で、
送信成功したら、ボタンの表記を「送信成功」に、
失敗したら、「送信失敗」にしたいです。

発生している問題・エラーメッセージ

フォームに入力・送信する前から(メールフォームを表示させた段階で)既に
「送信成功」になっています。

エラーメッセージ

該当のソースコード

HTML
<div id="form">
<form action="contact.php" method="post">
            <p>Name</p>
            <p><input type="text" name="namae" size="50px" placeholder="お名前" required  class="def fm"></p>
            <p>Email</p>
            <p><input type="email" name="email" size="50px" placeholder="メールアドレス"  class="def fm"></p>
            <p>Message</p>
            <p><textarea name="message" rows="3" cols="50" placeholder="メッセージをどうぞ"  class="def fm"></textarea></p>
            <p><input type="submit" value="SUBMIT" class="btn btn-a btn-b icon-envelope" required id="send"></p>
</form>
PHP (+jQuery)

<script src="http://code.jquery.com/jquery-1.11.1.min.js"></script> 


<?php //error_reporting(E_ALL | E_STRICT);


//文字コード設定
mb_language("Japanese");
mb_internal_encoding("UTF-8");

//*環境設定*************************************
//件名
$subject = "お問い合わせ";
//管理人メールアドレス(宛先)
$to = "xxx@gmail.com";
//**********************************************

//**POSTデータ受け取り**************************
//差出人メールアドレス格納
$header = "From: ". $_POST["email"];
$header = "From:". $_POST["namae"] ."\n";

//本文格納
$body = "■メールアドレス:" . $_POST["email"] ."\n";
$body .= "■内容:" . $_POST["message"] ."\n";

//************************************************

 echo "<script type='text/javascript'>
                        $(function() {
                          $('#send').attr('value','SUBMIT!');
                        });
                 </script>";

if ($_SERVER['METHOD'] == 'POST') {                 
if(mb_send_mail($to,$subject,$body,$header)){
        echo "<script type='text/javascript'>
                        $(function() {
                          $('#send').attr('value','SUBMIT!'); 
                        });
                   </script>"; //SUCCESSにしたいけど
}else{
        echo "<script type='text/javascript'>
                        $(function() {
                          $('#send').attr('value','ERROR!');
                        });
                 </script>";
}
}
?>

</body>
</html>

PHPにあまり詳しくないので、できるだけ省略しないで教えてもらえるとありがたいです。
よろしくお願いします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • Y.H.

    2016/11/11 21:11

    現象が再現する最低限のコードを提示できませんか? HTML・*.phpの構成とかさっぱりわからないです。

    キャンセル

  • 退会済みユーザー

    2016/11/12 23:03

    こちらの質問が他のユーザから「やってほしいことだけを記載した丸投げの質問」という指摘を受けました
    「質問を編集する」ボタンから編集を行い、調査したこと・試したことを記入していただくと、回答が得られやすくなります。

  • sascha

    2016/11/14 18:46

    エラー改善に手を出せるほどのスキルがないので、本当にどうしたら良いのかわからず質問することしかできませんでした。もしこのような質問には回答したくないのであれば回答しないで大丈夫です。

    キャンセル

回答 3

0

画面遷移とファイル構成がさっぱり記載されていないので
エスパー能力を駆使して回答してみます。

入力フォームもSUBMITさきも同じPHPで作成しているとして
入力フォームがGETでアクセスされ、submit はPOSTでアクセスするつくりなら
POSTでアクセスされた時だけメール送信処理すればいいのでは?

if ($_SERVER['METHOD'] == 'POST') {
    //**POSTデータ受け取り**************************
    //差出人メールアドレス格納
    $header = "From: ". $_POST["email"];
    $header = "From:". $_POST["namae"] ."\n";

    //本文格納
    $body = "■メールアドレス:" . $_POST["email"] ."\n";
    $body .= "■内容:" . $_POST["message"] ."\n";

    //************************************************
    if(mb_send_mail($to,$subject,$body,$header)){
            echo "<script type='text/javascript'>
                            $(function() {
                              $('#send').attr('value','SUCCESS!');
                            });
                       </script>";
    }else{
            echo "<script type='text/javascript'>
                            $(function() {
                              $('#send').attr('value','ERROR!');
                            });
                     </script>";
    }
}

質問の編集(コードのMETHOD判定追加)を受けて追記

フォームに入力・送信する前から(メールフォームを表示させた段階で)既に 
「送信成功」になっています。

メールフォームを表示させるのにGETでアクセスしているなら

if ($_SERVER['METHOD'] == 'POST') {

のif ブロックに入るはずがないので ifブロックの中で valueを"SUCCESS!"にしても実行されるはずがないです。まずはこの前提が真なのか偽なのかを提示いただかないと何もアドバイスできません。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/11/12 22:55

    これだけソースファイルを変更して「特に何も変わりませんが」ということありえないのですが。。。
    編集しているソースファイルと実行しているものが異なっているのでは?

    キャンセル

  • 2016/11/12 22:57

    多分これ以上はお役に立てないと思います

    キャンセル

  • 2016/11/14 16:50

    そうなんですね、ありがとうございました。

    キャンセル

0

フォームに入力・送信する前から(メールフォームを表示させた段階で)既に 
「送信成功」になっている原因は、以下のソースが入っているからだと思います。
※「if ($_SERVER['METHOD'] == 'POST') {   」の前

echo "<script type='text/javascript'>
                        $(function() {
                          $('#send').attr('value','SUBMIT!');
                        });
                 </script>";

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/11/12 16:11

    回答ありがとうございます。

    そのソースはあってもなくても変わらないです。

    キャンセル

0

ボタンのラベルを変えるだけのサンプル・スクリプト

<?php
ini_set('display_errors', 1);
error_reporting(E_ALL);

function h($string)
{
    return htmlspecialchars($string, ENT_QUOTES, 'utf-8');
}

$label = '送信';
if (filter_input(INPUT_SERVER, 'REQUEST_METHOD') == 'POST') {
    $result = filter_input(INPUT_POST, 'result');
    if ($result) {
        $label = '成功しました';
    } else {
        $label = '失敗しました';
    }
}
?><!DOCTYPE HTML>
<html lang="ja">
    <head>
        <meta charset="UTF-8">
        <title></title>
    </head>
    <body>
        <form action="" method="post">
            <p>
                <label>
                    <input type="radio" name="result" value="1" checked="checked" /> 成功時
                </label>
            </p>
            <p>
                <label>
                    <input type="radio" name="result" value="0" /> 失敗時
                </label>
            </p>
            <p>
                <button type="submit"><?= h($label); ?></button>
            </p>
        </form>
    </body>
</html>

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/11/14 16:49

    回答ありがとうございます。

    作りたかったのは、まさにこのようなボタンです。このスクリプトをうまく組み込めるかわかりませんが、とても参考になりました。ありがとうございます。

    キャンセル

  • 2016/11/14 18:18

    JavaScriptは不要です。

    キャンセル

  • 2016/11/14 18:38

    アドバイスありがとうございます。了解しました。やってみます。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 87.49%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る