2016-03-14 3 views
-1

Ниже приведен код моей PHP-формы на моем веб-сайте (я ее не писал). Это хорошо работает (и я вижу, с какой страницы отправлено сообщение), но когда я получаю электронное письмо, я также хотел бы узнать, отправил ли пользователь сообщение с смартфона или с mac, если он использовал сафари или firefox и т. д. Я понимаю, что $_SERVER ['HTTP_USER_AGENT']; - это то, что мне нужно. Проблема в том, что я не уверен, как/где добавить это в существующий код, поскольку я не знаком с синтаксисом PHP? Большое спасибо за вашу помощьКак добавить HTTP_USER_AGENT в мою php-форму?

<?php 
// Email Submit 
// Note: filter_var() requires PHP >= 5.2.0 
if (isset($_POST['email']) && isset($_POST['name']) && isset($_POST['message']) && filter_var($_POST['email'], FILTER_VALIDATE_EMAIL)) { 

    // detect & prevent header injections 
    $test = "/(content-type|bcc:|cc:|to:)/i"; 
    foreach ($_POST as $key => $val) { 
    if (preg_match($test, $val)) { 
     exit; 
    } 
    } 

    //send email 
mail("[email protected]", "New message from: ".$_POST['name'], $_POST['message']."\nFrom this page: ". str_replace("http://", "", $_SERVER['HTTP_REFERER']), "From:" . $_POST['email'] . "\r\n" . "BCC: [email protected]"); 

} 
?> 

и JS:

// Contact Form 
$(document).ready(function() { 
    $("#contactfrm").submit(function(e) { 
     e.preventDefault(); 
     var name = $("#name").val(); 
     var email = $("#email").val(); 
     var message = $("#message").val(); 
     var dataString = 'name=' + name + '&email=' + email + '&message=' + message; 

     function isValidEmail(emailAddress) { 
      var pattern = new RegExp(/^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i); 
      return pattern.test(emailAddress); 
     }; 
     if (isValidEmail(email) && (message.length > 1) && (name.length > 1)) { 
      $.ajax({ 
       type: "POST", 
       url: "sendfrm.php", 
       data: dataString, 
       success: function() { 
        $('button[name="submit"]').hide(); 
        $('.error').hide() 
        $('.success').fadeIn(1000); 
       } 
      }); 
     } else { 
      $('.error').fadeIn(1000); 
     } 
     return false; 
    }); 

}); 
+3

Точно так же вы добавили '$ _POST ['name']' и все остальные данные, которые вы читаете из супер-глобальных. – Quentin

+0

Спасибо, но я не написал код. Я полный новичок в PHP. Я добавил к своему сообщению JS-скрипт, связанный с формой. Я вижу, что в поле электронной почты уже сделаны некоторые проверки. Считаете ли вы, что он все еще уязвим для ввода заголовков? Tks – Greg

+0

@Greg - Это совершенно отдельный вопрос и, вероятно, лучше подходит для Code Review SE. –

ответ

0

Добавим, что к линии тела в функции mail(). Простейший, я не знаю, должен ли я ответить, или если я должен закрыть это как оффтоп. Но вот вы ответ (см. Стрелку для дополнительных подсказок):

mail("[email protected]", "New message from: ".$_POST['name'], $_POST['message']."\nFrom this page: ". str_replace("http://", "", $_SERVER['HTTP_REFERER'])."\nAnd from this user agent: ". $_SERVER['HTTP_USER_AGENT'], "From:" . $_POST['email'] . "\r\n" . "BCC: [email protected]"); 
---------------------------------------------------------------------------------------------------------------------------------------------------------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 
Смежные вопросы