ruby-on-rails – Devise正在登录到不同的路线

我有一个非常奇怪的问题与Devise.我设置了一个路由,接受get和post请求.在一个get,它显示表单,在帖子,它提交它.

当我发个帖子XHR的路线,当它到达那里它告诉我,我没有登陆,并给我发送401未授权.之后,我必须登录,然后我可以再试一次.

我一直在试图弄清楚这一点了几个小时,所有的我已经能够搞清楚的是,我的控制器方法是没有得到调用.我把我自己的自定义过滤器AUTH之前,它只是证实了我的Rails应用程序被调用时,用户不再登录.

此外,如果我打开表单,但不提交,我可以继续正常.在那个XHR的某个地方,它正在使设计成功地记录我.

如果您有任何想法请帮忙,我不知道现在发生了什么事情

谢谢

斯科特

编辑:添加相关代码段

的routes.rb

match 'projects/:p/filebox' => 'projects#show',:via => ["get","post"],:as => 'project_filebox'

projects_controller.rb

before_filter :authenticate_user! # <--- By the time this gets called,the user is logged out
def show
# ^^^^ Doesnt get called. Logger shows that it recognized route though
logger.debug "-----------projects#show"
logger.debug "Current user logged in:"+user_signed_in?.to_s

正在提交的表单

<form class="upload" action="<%= project_filebox_path(@project) %>?n=7&cType=<%= cType %>&fid=<%= fid %>" method="post" enctype="multipart/form-data">
    <input type="file" name="file" multiple/>
    <button>Upload</button>
    <div>Add / Drag Files To Upload</div>
</form>

正在上传XHR的Javascript

formDataUpload = function (files,xhr,settings) {
            var formData = new FormData(),i;
            $.each(getFormData(settings),function (index,field) {
                formData.append(field.name,field.value);
            });
            for (i = 0; i < files.length; i += 1) {
                formData.append(settings.fieldName,files[i]);
            }
            xhr.send(formData);
        }

如果我错过了一些相关代码让我知道

解决方法

除了JS之外,这里还没有太多的东西,但是由于没有将CSRF令牌设置为请求的一部分,因此您遇到了一个很大的变化.这在各种Rails 3.0.x版本中已经改变,所以很难知道没有代码.

一个简单的测试将是关闭CSRF(例如从ProtectController中删除protect_from_forgery).如果它有效,你有答案,需要确保令牌被传递,否则处理伪造的保护.

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...