0

私は 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\" }"
4

1 に答える 1