私は CodeIgniter を使用しており、jquery$.ajax()
関数を使用してコントローラーから返される JSON 値を取得しようとしています。これが私の「ログイン/プロセス」コントローラーです
public function process() {
$this->form_validation->set_rules('email','Email Address','trim|required|xss_clean');
$this->form_validation->set_rules('passwd','Password','trim|required|xss_clean|md5|callback_check_database');
$red = ($this->input->post('redirect_url')) ? $this->input->post('redirect_url') : null;
if ($this->form_validation->run() == false) {
$output = '{ "success": "no", "redirct": "' . $red . '", "err" : "' .validation_errors() . '" }' ;
} else {
//Go to private area
$output = '{ "success": "yes", "redirct": "account" , "err" : ""}';
}
}
header('Content-Type: application/json', true);
echo json_encode($output);
}
}
以下は私の見解の一部です。
<script type='text/javascript' language='javascript'>
$(document).ready(function() {
$("#LoginForm").on("submit",function() {
var datastring = 'email='+$("#email").val()+'&passwd='+$("#passwd").val()+'&redirect_url='+$("#redirect_url").val();
$.ajax({
type: "POST",
url: "<?= base_url("login/process") ?>",
dataType: "json",
data: datastring,
cache: false,
success: function(output) {
// alert(output.success);
if (output.success == 'yes') {
document.location.href=output.redirct
}
if (output.success == 'no') {
alert(output.err)
}
}
})
return false; // To prevent form submission
})
});
</script>
FireBug でデバッグしようとしたとき、以下は POST 応答として取得したものです。
"{ \"success\": \"no\", \"redirct\": \"messaging.php\", \"err\" : \"<p>The Password field is required.<\/p>\n\" }"