使用Rails remote设置ajax登录/注册:true

时间:2013-02-04 10:08:53

标签: ruby-on-rails devise

我的表单中没有remote: true,登录有效。但是,当使用remote: true并尝试通过ajax登录时,我收到此错误:

You need to sign in or sign up before continuing.

请求都是帖子。有人可以启发我吗?

1 个答案:

答案 0 :(得分:4)

您需要遵循以下步骤:

1)检查所提出的请求是否为javascript。

验证是否应检查请求标头以查看Accept参数是什么。如果它说application/javascript那么一切都很好。使用firebug等工具轻松检查请求标题。

2)包含哪些javascript文件?

其次,在开始试用:remote => true时,一个非常常见的问题是所需的 javascript库未包含在您的代码中。所以我的猜测是你的布局中缺少以下代码:

<%= javascript_include_tag :defaults %>
<%= csrf_meta_tag %>

如果是这种情况,请将其包含在html标题内。

3)检查控制器:它是否有响应阻止?

如果您使用rails generate scaffold生成了应用,则会有类似

的内容
 respond_to do |format|
      format.html
      format.xml  { .... }
    end

将上述代码替换为:

respond_to :html, :js

respond_to do |format|
      format.html
      format.js
      format.xml  { .... }
    end

4)在您的application.js中设置CSRF令牌

$(function(){
  $.ajaxSetup({
    beforeSend: function( xhr ) {
      var token = $('meta[name="csrf-token"]').attr('content');
      if (token) xhr.setRequestHeader('X-CSRF-Token', token);
    }
  });
});

5)发布您的登录信息

$.ajax({
  url: '/users/sign_in.json',
  type: 'POST',
  dataType: 'json',
  data: {user: {email: 'email@example.com', password: 'password'}},
  success: function(data, textStatus, xhr) {
    //called when successful
  }
});