javascript - Ajax 请求未完成
问题描述
我正在制作一个订阅时事通讯的表格,为此我使用 ajax 请求来调用 mailchimp api。api单独工作正常,我已经测试过了。但是在 ajax 代码中,我在 beforeSend 和 complete 部分发出警报,它是正确的,但在成功时它什么也不做。
这是我的代码:
HTML 表单代码
<form id="mc-embedded-subscribe-form" name="mc-embedded-subscribe-form" class="validate">
<input type="email" value="" name="EMAIL" class="email" id="useremail" placeholder="Type our mail address" required>
<input type="button" value="subscribe" name="subscribe" id="mc-embedded-subscribe" class="mc-button" >
<div id="subscribe-result">
</div>
</form>
脚本代码
<script>
$("#mc-embedded-subscribe").click(function() {
var email = $('#useremail').val();
$.ajax({
type: 'post',
url: "newslatter.php",
dataType: 'json',
data: 'useremail='+email,
beforeSend: function() {
},
complete: function() {
},
success: function(data)
{
alert("enter success");
if(data.type == 'error')
{
output = "<a color='red'>"+data.text+"</div>";
}else{
output = data.text;
}
$("#subscribe-result").html(output);
}
});
});
</script>
这是NewsLatter 的 PHP 代码
<?php
if ($_SERVER['REQUEST_METHOD'] == 'POST') {
//check if its an ajax request, exit if not
if (!isset($_SERVER['HTTP_X_REQUESTED_WITH']) AND strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) != 'xmlhttprequest') {
//exit script outputting json data
$output = json_encode(
array(
'type' => 'error',
'text' => 'Request must come from Ajax'
));
die($output);
}
//check $_POST vars are set, exit if any missing
if ( !isset($_POST["useremail"]) ) {
$output = json_encode(array('type' => 'error', 'text' => 'Input fields are empty!'));
die($output);
}
//Sanitize input data using PHP filter_var().
$useremail = filter_var(trim($_POST["useremail"]), FILTER_SANITIZE_EMAIL);
//additional php validation
if (!filter_var($useremail, FILTER_VALIDATE_EMAIL)) { //email validation
$output = json_encode(array('type' => 'error', 'text' => 'Please enter a valid email!'));
die($output);
}
$list_id = '***secret***';
$api_key = '***secret***';
$data_center = substr($api_key,strpos($api_key,'-')+1);
$url = 'https://'. $data_center .'.api.mailchimp.com/3.0/lists/'. $list_id .'/members';
$json = json_encode([
'email_address' => $email,
'status' => 'subscribed', //pass 'subscribed' or 'pending'
]);
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_USERPWD, 'user:' . $api_key);
curl_setopt($ch, CURLOPT_HTTPHEADER, ['Content-Type: application/json']);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_TIMEOUT, 10);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_POSTFIELDS, $json);
$result = curl_exec($ch);
$status_code = curl_getinfo($ch, CURLINFO_HTTP_CODE);
curl_close($ch);
if ($status_code!=200) {
$output = json_encode(array('type' => 'error', 'text' => 'Something Went Wrong'));
die($output);
} else {
$output = json_encode(array('type' => 'message', 'text' => 'Hi ' . $username . ' Thank you for your email'));
die($output);
}
?>
解决方案
添加
header('Content-Type: application/json');
在发送 json 响应之前在 php 中
在文件的和处还需要一个大括号“}”来关闭块
if ($_SERVER['REQUEST_METHOD'] == 'POST') {
推荐阅读
- c# - 我可以使用 Dynamics 365 中的 SharedVariables 在 CodeActivity(工作流)和插件之间传递信息吗?
- javascript - 使用表中的引导按钮插件突出显示多个选项
- android - Android Studio:仅过滤消息窗口或构建窗口中的错误?
- java - 如何通过 Java 代码通过从 Java 中的文本字段中获取值来重命名 MySQL 中的列名?
- hive - 失败:执行错误,从 org.apache.hadoop.hive.ql.exec.mr.MapRedTask 返回代码 -101。com/yammer/metrics/core/MetricsRegistry
- laravel - Laravel 5.8 Vue 组件在安装后不更新
- algorithm - 这是什么排序算法,可以改进吗?
- kotlin - 带有 leptonica 问题的 Kotlin-native C-interop
- c# - 在基于 ARKit 标记的场景之间切换会导致应用崩溃
- python - 给定一列具有特定值的编辑数据框的行