введите значение в тему письма - php mailer - PullRequest
0 голосов
/ 08 мая 2018

Я хочу, чтобы значение поля имени отображалось в теме письма от пользователя моего сайта. Я использую плагин phpmailer. В настоящее время отображается «Сообщение от пользователя».

handler.php:

$pp = new FormHandler(); 

$validator = $pp->getValidator();
$validator->fields(['name','email'])->areRequired()->maxLength(50);
$validator->field('email')->isEmail();
$validator->field('message')->maxLength(6000);
$validator->CharSet = 'UTF-8';

FormHandler.php:

public function __construct()
{
    $this->emails = array();
    $this->validator = FormValidator::create();
    $this->mailer = new PHPMailer;
    $this->mail_template='';

    $this->mailer->Subject = "Message from the user";

    $host = isset($_SERVER['SERVER_NAME'])?$_SERVER['SERVER_NAME']:'localhost';
    $from_email ='forms@'.$host;
    $this->mailer->setFrom($from_email,'BanerBunny.pl',false);

    $this->captcha = false;   

    $this->attachments = [];

    $this->recaptcha =null;
}

и html:

<div id="form-main">
   <div id="form-div">
      <form class="montform" id="reused_form" enctype=&quot;multipart/form-data&quot;>
         <p class="name">
            <input name="name" type="text" class="feedback-input" placeholder="Imię i Nazwisko"
                   id="name" required/>
         </p>
      </form>
   </div>
</div>

Ответы [ 2 ]

0 голосов
/ 30 мая 2018

Вместо из:

$this->mailer->Subject = "Message from the user";

Попробуйте использовать:

$this->mailer->Subject = ($_POST['name']);

Должно работать нормально.

0 голосов
/ 08 мая 2018

Форма отправляет код через JQuery / AJAX Да, я пытался использовать эту переменную: $ this-> mailer-> Subject = $ validator-> field ('name'). К сожалению, форма не отправляется вообще.

form.js

$(function () {
function after_form_submitted(data) {
    if (data.result == 'success') {
        $('form#reused_form').hide();
        $('#success_message').css('display', 'flex');
        $('#error_message').hide();
    }
    else {
        $('#error_message').append('<ul></ul>');

        jQuery.each(data.errors, function (key, val) {
            $('#error_message ul').append('<li>' + key + ':' + val + '</li>');
        });
        $('#success_message').hide();
        $('#error_message').show();

        //reverse the response on the button
        $('button[type="button"]', $form).each(function () {
            $btn = $(this);
            label = $btn.prop('orig_label');
            if (label) {
                $btn.prop('type', 'submit');
                $btn.text(label);
                $btn.prop('orig_label', '');
            }
        });

    }//else
}

$('#reused_form').submit(function (e) {
    e.preventDefault();

    $form = $(this);
    //show some response on the button
    $('button[type="submit"]', $form).each(function () {
        $btn = $(this);
        $btn.prop('type', 'button');
        $btn.prop('orig_label', $btn.text());
        $btn.text('Wysyłanie ...');
    });


    var formdata = new FormData(this);
    $.ajax({
        type: "POST",
        url: 'handler.php',
        data: formdata,
        success: after_form_submitted,
        dataType: 'json',
        processData: false,
        contentType: false,
        cache: false
    });

});
...