我正在尝试通过 AJAX 使用 CodeIgniter 发送表单构建,并尝试使用 JSON 获取响应。但是,我只在打开开发人员选项卡时看到响应(我什至不确定这是否实际上是响应,因为它显示了两个 json 数据)。
它所显示的只是加载旋转器,然后它就消失了。
代码已经在没有 AJAX 的情况下进行了测试并且可以正常工作,因此 PHP 中不会出现错误。
这是我用于重置密码的控制器:
<?php
Class Users extends CI_Controller {
public function forgot_pass()
{
if(!$this->input->post('to_email'))
{
exit("No data");
}
$this->load->model('user');
$email = $this->input->post('to_email');
$email_addr = $this->user->get_email_address($email);
if(empty($email_addr))
{
echo json_encode(array('pls'=>0, 'msg' => "E-mail address was not found. Try again"));
}
$this->load->helper('string');
$new_password = random_string('alnum', 8);
$this->load->library('phpass');
$update_password = array( 'password' => $this->phpass->hash($new_password));
$update_password = $this->user->update_password($email, $update_password);
$this->load->library('email');
$config['newline'] = '\r\n';
$this->email->initialize($config);
$this->email->from('[email protected] /cdn-cgi/l/email-protection', 'Your Name');
$this->email->to($email);
$this->email->subject('New password');
$this->email->message("Hey, " .$email_addr['name']. ". Your new password is: " .$new_password);
if($this->email->send())
{
echo json_encode(array('pls'=>1, 'msg' => "Password has been sent to given e-mail address"));
}
}
}
?>
这是我用 jQuery 编写的 AJAX 调用:
$(document).ready(function() {
$("form#forget_pass_form").on('submit', function(e){
e.preventDefault();
$("#loading_spinner").show();
var from = $(this);
$.ajax({
url: from.attr('action'),
type: from.attr('method'),
data: $(from).serialize(),
}).done(function(data) {
if(data.pls == 0) {
$("#forgot-pass-success").hide();
$("#forgot-pass-error").show();
$("#forgot-pass-error").fadeIn(1000).html(data.msg);
}
if(data.pls == 1) {
$("#forgot-pass-error").hide();
$("#forgot-pass-success").show();
$("#forgot-pass-success").fadeIn(1000).html(data.msg);
}
$("#loading_spinner").hide();
});
return false;
});
});
首先,您可以尝试在控制器中设置正确的标头吗?
header('Content-Type', 'application/json');
或者更好的是:
$this->output->set_content_type('application/json');
作为旁注,您应该确保始终返回 JSON 数据,因此我将删除exit()
消息并将默认的 JSON 响应放在方法的底部。
不要忘记,当你回显 JSON 时,你可以把return;
之后停止该方法中以后运行的任何更多代码。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)