Почему моя форма новостной рассылки не работает в Amazon CloudFront?

Я использую HTML и использую amazon EC2 (бесплатный уровень Linux). Я хотел бы использовать CloudFront, но моя новостная рассылка не будет работать. Я не эксперт по AWS, и я понятия не имею, почему он не будет работать на CloudFront.

Моя форма рассылки выглядит так:

 <form id="subscribe" class="form" action="<?=$_SERVER['PHP_SELF']; ?>" method="post">
<div class="form-group form-inline">
<input size="15" type="text" class="form-control required" id="NewsletterName" name="NewsletterName" placeholder="Your name" />
<input size="25" type="email" class="form-control required" id="NewsletterEmail" name="NewsletterEmail" placeholder="[email protected]" />
<input type="submit" class="btn btn-default" value="SUBSCRIBE" />
<span id="response">
<? require_once('assets/mailchimp/inc/store-address.php'); if($_GET['submit']){ echo storeAddress(); } ?>
</span>
</div>
</form>

и мой файл js выглядит так:

jQuery(document).ready(function() {
jQuery('#subscribe').submit(function() {
// update user interface
jQuery('#response').html('<span class="notice_message">Adding email address...</span>');var name = jQuery('#NewsletterName').val().split(' ');

var fname = name[0];
var lname = name[1];

if ( fname == '' ) { fname=""; }
if ( lname == '' || lname === undefined) { lname=""; }
// Prepare query string and send AJAX request
jQuery.ajax({
url: 'assets/mailchimp/inc/store-address.php',
data: 'ajax=true&email=' + escape(jQuery('#NewsletterEmail').val()),
success: function(msg) {

if (msg.indexOf("Success") !=-1) {
jQuery('#response').html('<span class="success_message">Success! You are now
subscribed to our newsletter!</span>');
} else {
jQuery('#response').html('<span class="error_message">' + msg + '</span>');
}
}
});

return false;
});
});

и мой PHP-файл выглядит так:

<?php

function storeAddress(){

require_once('MCAPI.class.php');  // same directory as store-address.php

// grab an API Key from http://admin.mailchimp.com/account/api/
$api = new MCAPI('mymailchimpapi');

$merge_vars = Array(
'EMAIL' => $_GET['email'],
'FNAME' => $_GET['fname'],
'LNAME' => $_GET['lname']
);

// grab your List's Unique Id by going to http://admin.mailchimp.com/lists/
// Click the "settings" link for the list - the Unique Id is at the bottom of that page.
$list_id = "myuniqueid";

if($api->listSubscribe($list_id, $_GET['email'], $merge_vars , $_GET['emailtype']) === true) {
// It worked!
return 'Success!&nbsp; Check your inbox or spam folder for a message containing a
confirmation link.';
}else{
// An error ocurred, return error message
return '<b>Error:</b>&nbsp; ' . $api->errorMessage;
}

}

// If being called via ajax, autorun the function
if($_GET['ajax']){ echo storeAddress(); }
?>

Форма работает, когда я получаю к ней доступ без использования CloudFront, но меня беспокоит пропускная способность сервера, поэтому я хочу использовать CloudFront. Что происходит, когда вы нажимаете кнопку «Отправить», сообщение «добавление адреса электронной почты» будет отображаться в течение 1 секунды, а введенный адрес электронной почты игнорируется.

1

Решение

Убедитесь, что ваш дистрибутив CloudFront действительно настроен для обработки запросов POST / PUT. Посмотрите здесь для деталей: http://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/distribution-web-values-specify.html#DownloadDistValuesAllowedHTTPMethods

0

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

Других решений пока нет …

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