PHP $ _POST пуст при отправке из формы AngularJS с помощью общего хостинга GoDaddy

Я работаю над созданием контактной формы на моем сайте, но не могу заставить работать PHP. Я могу получить электронное письмо для отправки на мой электронный адрес, но все пусто, что я получил бы из метода $ _POST. Я очень плохо знаком с PHP, но у меня большой опыт работы с AngularJS. Любая помощь будет оценена.

PHP:

<?php
$to         = '[email protected]';
$subject    = $_POST["subject"];
$message    = $_POST["message"];
$fromEmail  = $_POST["email"];
$fromName   = $_POST["name"];
$headers    = 'From: '.$fromName.' <'.$fromEmail.'>'."\r\n".'Reply-To: '.$fromEmail."\r\n".'X-Mailer: PHP/'.phpversion();

mail($to, $subject, $message, $headers, "[email protected]");
?>

HTML:

<form name="contactForm" ng-submit="submit()" novalidate>
<div class="row">
<div class="col-md-6" ng-class="{'has-error' : contactForm.firstName.$invalid && !contactForm.firstName.$pristine}">
<label for="firstName">First Name:</label>
<input type="text" placeholder="Joe" class="form-control ng-pristine ng-invalid ng-invalid-required ng-valid-minlength" name="firstName" ng-model="firstName" required />
</div>
<div class="col-md-6" ng-class="{'has-error' : contactForm.lastName.$invalid && !contactForm.lastName.$pristine}">
<label for="lastName">Last Name:</label>
<input type="text" placeholder="Schmoe" class="form-control ng-pristine ng-invalid ng-invalid-required ng-valid-minlength" name="lastName" ng-model="lastName" required />
</div>
</div>
<div class="row">
<div class="col-md-12" ng-class="{'has-error' : contactForm.email.$invalid && !contactForm.email.$pristine}">
<label for="email">Email Address:</label>
<input type="email" placeholder="[email protected]" class="form-control ng-pristine ng-invalid ng-invalid-required ng-valid-minlength" name="email" ng-model="email" required />
</div>
</div>
<div class="row">
<div class="col-md-12" ng-class="{'has-error' : contactForm.subject.$invalid && !contactForm.subject.$pristine}">
<label for="subject">Subject:</label>
<input type="subject" placeholder="Help me!" class="form-control ng-pristine ng-invalid ng-invalid-required ng-valid-minlength" name="subject" ng-model="subject" required />
</div>
</div>
<div class="row">
<div class="col-md-12" ng-class="{'has-error' : contactForm.body.$invalid && !contactForm.body.$pristine}">
<label for="body">Body:</label>
<textarea style="width: 100%; height: 173px; resize: none;" type="subject" placeholder="I am stuck inside this website and want out!  I have been here for years and years..." class="form-control ng-pristine ng-invalid ng-invalid-required ng-valid-minlength" name="body" ng-model="body" required />
</div>
</div>
<div class="row">
<div class="col-md-offset-2 col-md-8">
<br />
<button type="submit" class="btn btn-success col-md-12" ng-disabled="contactForm.$invalid">
<h4>Send me an email!</h4>
</button>
</div>
</div>
</form>

JS:

window.dp.controller('ContactController', ['$scope', '$http', function($scope, $http) {
$scope.firstName = new String();
$scope.lastName = new String();
$scope.email = new String();
$scope.subject = new String();
$scope.body = new String();

$scope.submit = function() {
$scope.fullName = $scope.firstName + ' ' + $scope.lastName;

$scope.config = {
params: {
name: $scope.fullName,
email: $scope.email,
subject: $scope.subject,
message: $scope.body
}
};

$http.post("/php/contact.php", null, $scope.config)
.success(function(result){
// show success msg
}).error(function(result){
// show error msg
});
//
};
}]);

Я немного разбирался в этой проблеме, но большинство исправлений было добавлено в name Атрибут для тегов ввода HTML. Я посмотрел на этот ответ, но это не похоже на работу для меня.

РЕДАКТИРОВАТЬ:

Просто нашел журнал ошибок для contact.php со следующим содержимым:

[20-Apr-2015 02:03:07 UTC] PHP Notice:  Undefined index: subject in /home/[mydomainname]/public_html/dp/php/contact.php on line 3
[20-Apr-2015 02:03:07 UTC] PHP Notice:  Undefined index: message in /home/[mydomainname]/public_html/dp/php/contact.php on line 4
[20-Apr-2015 02:03:07 UTC] PHP Notice:  Undefined index: email in /home/[mydomainname]/public_html/dp/php/contact.php on line 5
[20-Apr-2015 02:03:07 UTC] PHP Notice:  Undefined index: name in /home/[mydomainname]/public_html/dp/php/contact.php on line 6

Я заменяю часть пути в приведенном выше журнале на [mydomainname], чтобы скрыть, на каком домене он находится, а также сокращал журнал, поскольку эти 4 строки повторялись каждый раз, когда я пытался отправить электронное письмо.

Я также непосредственно пытался создать этот файл с набором параметров, но у меня был тот же результат, что и раньше, что заставляет меня думать, что что-то странное происходит между браузером, выполняющим запрос, и файлом contact.php, получающим запрос.

0

Решение

Ваш второй параметр $http.post должны быть данные, но у вас есть null,

Прочитайте руководство http Вот.

0

Другие решения

Итак, я узнал, что я делаю не так. Очевидно, что если вы хотите получить доступ к ПАРАМЕТРАМ запроса HTTP POST, вы должны использовать $_REQUESTтогда как если вы хотите получить доступ к ДАННЫМ HTTP-запроса POST, вы должны использовать $_POST,

Мой новый PHP выглядит следующим образом:

<?php
$to         = '[email protected]';
$subject    = $_REQUEST["subject"];
$message    = $_REQUEST["message"];
$fromEmail  = $_REQUEST["email"];
$fromName   = $_REQUEST["name"];
$headers    = 'From: '.$fromName.' <'.$fromEmail.'>'."\r\n".'Reply-To: '.$fromEmail."\r\n".'X-Mailer: PHP/'.phpversion();

mail($to, $subject, $message, $headers, "[email protected]");
?>

Надеюсь, что это поможет любому с этой проблемой!

0

По вопросам рекламы [email protected]