web-dev-qa-db-fra.com

Après la mise à niveau vers PHP 7.0 erreur de sortie du formulaire de contact

Mise à niveau du site de PHP 5.6 à PHP 7.0. Après la mise à niveau, il y avait une erreur de code avec eregi() obsolète, que j'ai remplacée par preg_match() plus tard, mais maintenant, l'erreur est générée à chaque fois que je soumets un formulaire rempli.

C'est probablement évident, mais je suis débutant en PHP, je viens d'apprendre.

C'est le code complet de mon formulaire de contact:

<?php
    /*
    Template Name: Обратная связь
    */

    if(isset($_POST['submitted'])) {
        if(trim($_POST['contactName']) === '') {
            $nameError = 'Please enter your name.';
            $hasError = true;
        } else {
            $name = trim($_POST['contactName']);
        }
        if(trim($_POST['email']) === '')  {
            $emailError = 'Please enter your email address.';
            $hasError = true;
        } else if (!preg_match("/^[A-Z0-9.%-]+@[A-Z0-9.%-]+.[A-Z]{2,4}$/", trim($_POST['email']))) {
            $emailError = 'You entered an invalid email address.';
            $hasError = true;
        } else {
            $email = trim($_POST['email']);
        }
        if(trim($_POST['comments']) === '') {
            $commentError = 'Please enter a message.';
            $hasError = true;
        } else {
            if(function_exists('stripslashes')) {
                $comments = stripslashes(trim($_POST['comments']));
            } else {
                $comments = trim($_POST['comments']);
            }
        }
        if(!isset($hasError)) {
            $emailTo = get_option('tz_email');
            if (!isset($emailTo) || ($emailTo == '') ){
                $emailTo = get_option('admin_email');
            }
            $subject = "Отзыв от пользователя ".$name;
            $body = "Имя: $name 
    E-mail: $email 

    $comments";
            $headers = 'From: '.$name.' <'.$emailTo.'>' . "rn" . 'Reply: ' . $email;

        mail($emailTo, $subject, $body, $headers);
            $emailSent = true;
        }
    } ?>

    <?php get_header(); ?>
    <div class="row">
    <div class="paper">
    <div class="paper-body">
                            <?php if(isset($emailSent) && $emailSent == true) { ?>
       <h2 class="contact-form-thanks">
          Спасибо, ваше сообщение отправлено.
       </h2>
    <?php } else { ?>
    <?php if(isset($hasError) || isset($captchaError)) { ?>
       <p class="error">Извините, произошла ошибка.<p>
    <?php } ?>
    <form action="<?php the_permalink(); ?>" id="contactForm" method="post">

            <input class="contact-form-name" type="text" name="contactName" id="contactName" value="" placeholder="Имя" required>

              <input class="contact-form-email" type="email" name="email" id="email" value="" placeholder="E-mail" required>

           <textarea class="contact-form-text" name="comments" id="commentsText" rows="10" cols="30" value="" placeholder="Сообщение" required></textarea>

           <button type="submit">Отправить</button>
    <button type="reset">Очистить</button>
        <input type="hidden" name="submitted" id="submitted" value="true">
    </form>
    </div>
    </div>
    <?php } ?>
                    </div><!-- .entry-content -->

    <?php get_footer(); ?>
2
SLembas

Wordpress a une fonction intégrée pour valider les courriels et je vous conseillerais de l’utiliser.

Ainsi, vous pouvez remplacer votre preg_match par wordpress is_email

else if (!preg_match("/^[A-Z0-9.%-]+@[A-Z0-9.%-]+.[A-Z]{2,4}$/", trim($_POST['email']))) {
            $emailError = 'You entered an invalid email address.';
            $hasError = true;
        }

REMPLACÉ AVEC

else if ( ! is_email( trim( $_POST['email'] ) ) ) {
                $emailError = 'You entered an invalid email address.';
                $hasError = true;
            }

Vous devez également consulter le codex wordpress sur . Validation des données, en particulier la validation des entrées pour la désinfection des entrées utilisateur. avant de les utiliser dans votre code.

1
Tunji