Code Igniter Bonfire ajax请求500内部服务器错误

时间:2013-09-02 17:23:51

标签: php jquery ajax codeigniter bonfire

所以我试图使用ajax提交一个电子邮件地址让人们注册,我不知道为什么我会收到500内部服务器错误。我是ajax电话新手。

我尝试按照以下教程:http://www.youtube.com/watch?v=TZv5cgua5f0 但是我已经按照他们的说法完成了,如果我使用值进行操作,我就无法获得所需的控制器方法。如果我确实在帖子中添加数据,那么我会收到内部服务器错误。

的javascript:

$('#email_submit').click(function() 
    {

        var form_data = 
        {
           users_email: $('#users_email_address').val()
        };
        $.ajax
        ({
            url: 'http://localhost/myZone/NewsLetter/submit',
            type: 'POST',
            data: form_data,
            success: function(msg)
            {
                alert(msg);
            }

        });

        return false;
    });

HTML

<div id="email_newsletter_signup" class="ajax_email_block_signup" >
        <h3>Sign up to the newsletter:</h3>
        <?php echo form_error('signup_email','<div id="email_error" class="error">','</div>');?>
        <h3>email: <input id="users_email_address" type="email" name="signup_email" value="<?php echo set_value('signup_email'); ?>" placeholder="Your email"/> </h3>

        <input id="email_submit" type="submit" name="submit"/>
    </div>

位指示

    public function index()
        {
                Assets::add_module_js('newsletter','email.js');
                //If included will be added
                Template::set_block('email_block','email_block');
                Template::render();
        }

    public function submit($email)
            {
                $success = $this->newsletter_model->set_unverified_email($email);
//                if($success === FALSE)
//                {
//                    Template::set_block('newsletter_error','newsletter_error');
//                }
//                else
//                {
//                    Template::set_block('newsletter_success','newsletter_success');
//                }
//                Template::render();
                return;
            }

我在提交内部有一个断点,当我发帖子时它就不会被击中

由于

2 个答案:

答案 0 :(得分:1)

找到我的解决方案。与篝火无关,但与codeigniter无关。这是CSRF令牌。

以下是关于排序问题的优秀文章:

http://aymsystems.com/ajax-csrf-protection-codeigniter-20

答案 1 :(得分:0)

在发布

之前将csrf令牌添加到数据中
$.ajax({
            type: "POST",
            url: url,
            data: {'<?php echo $this->security->get_csrf_token_name(); ?>':'<?php echo $this->security->get_csrf_hash(); ?>'}

        })

需要在每个请求中发送csrf令牌,因此需要通过上述echo语句指定