草庐IT

before_session

全部标签

ruby-on-rails - 未定义的方法 `session_path'

我正在使用Rails+Devise+OmniAuth+GoogleOAuth2。我的用户模型(user.rb)包含:devise:registerable,:omniauthable,:omniauth_providers=>[:google_oauth2]我的routes.rb看起来像:Rails.application.routes.drawdodevise_for:users,controllers:{omniauth_callbacks:'omniauth_callbacks'}devise_scope:userdoget'sign_in',:to=>'devise/sessi

ruby-on-rails - 从清除 session 中停止设计

似乎当用户通过标准DeviseController注销时,Devise会销毁整个session存储,而不仅仅是它自己的数据。有什么办法可以避免这种行为?我还有其他不相关的数据应该保留。session[:my_var]="123"通过设计注销...putssession[:my_var]#=>nil 最佳答案 在devise的最新版本中,不需要覆盖sessionController,相反你可以使用:config.sign_out_all_scopes=false在devise.rb文件中获得所需的行为。

ruby-on-rails - Rails 3 额外的 session 配置选项(key、expires_after、secure)

谁能指出新的Rails3.xsession配置选项是什么?我正在尝试复制我在Rails2.3.x应用程序中的相同配置。这是我在应用程序中使用的配置:#environment.rbconfig.action_controller.session_store=:active_record_storeconfig.action_controller.session={:key=>'_something',#non-securefordevelopment:secret=>'reallylongrandomstring'}#production.rb-overrideenvironment.r

ruby - 使用 Rack::Session::Cookie 删除当前 session

我觉得我在这里遗漏了一些明显的东西,我希望一旦我发布这篇文章,就会有人用我遗漏的谷歌搜索链接来羞辱我:-)enable:sessionsget'/logout'do#Whatgoesheretokillthesession?end 最佳答案 就用session.clear销毁session。 关于ruby-使用Rack::Session::Cookie删除当前session,我们在StackOverflow上找到一个类似的问题: https://stackov

ruby-on-rails - 从 before(:each) block) 中获取完整的 RSpec 测试名称

RSpec允许您通过执行以下操作在before(:each)block中获取当前运行的测试方法名称:Spec::Runner.configuredo|config|config.before:eachdo|x|x.method_name#returns'shouldbecool'endend这是为了这样的测试:requireFile.expand_path(File.dirname(__FILE__)+'/../spec_helper')describe'Helloworld'doit'shouldbecool'do#testcodeendend是否有可能在beforeblock中获得

ruby-on-rails - Rails 3 禁用 session cookie

我在RoR3上编写了RESTfulAPI。我必须让我的应用程序不发送“Set-Cookieheader”(客户端使用auth_token参数进行授权)。我尝试过使用session:off和reset_session但它没有任何意义。我正在使用devise作为身份验证框架。这是我的应用程序ControllerclassApplicationController:session_required?session:off#,:unless=>:session_required?skip_before_filter:verify_authenticity_tokenbefore_filter:

ruby - 反对在 RSpec 测试中使用 before、let 和 subject 的理由是什么?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我刚开始编写RSpec测试,我遇到了thoughtbot'sStyleGuide,它反对let、let!、before和subject(以及其他)。我也在其他几个地方读过类似的建议(包括关于before(:all)的旧RSpecdocs警告),但我似乎找不到反对的实际论据他们。那么问题是:为什么我不应该在我的测试中使用这些方法?什么是更好的方法?

ruby - 在 Sinatra 中,你如何制作一个 "before"过滤器来匹配除某些路由之外的所有路由

我有一个RubySinatra应用程序,我有一些代码需要在除少数异常(exception)情况外的所有路由上执行。我该怎么做?如果我想在选定的路由(白名单样式)上执行代码,我会这样做:['/join',"/join/*","/payment/*"].eachdo|path|beforepathdo#somecodeendend我该如何反其道而行之(黑名单样式)?我想匹配除'/join'、'/join/*'和'/payment/*'之外的所有路由 最佳答案 负面前瞻:before/^(?!\/(join|payment))/do#..

ruby-on-rails - 有没有办法使 before_save 成为条件?

我正在尝试在Rails应用程序中进行有条件的before_save,但它似乎不起作用。before_savemethod_call_to_runifself.related_model.some_method_that_returns_t_or_f?如果“some_method_that_returns_t_or_f”返回true,我希望它在保存对象之前运行该方法,否则我只希望它忽略before_save。 最佳答案 你可以使用:ifbefore_savedo_something,:if=>Proc.new{|model|model

ruby-on-rails - Rails before_filter 用于 Controller 中的特定操作

defnewbefore_filterdoredirect_to"/"unlesscurrent_admin||current_companyflash[:notice]='Youdonthaveenoughpermissionstobehere'unlesscurrent_admin||current_companyendCODECODECODEenddefeditbefore_filterdoredirect_to"/"unlesscurrent_admin.id=5flash[:notice]='Youdonthaveenoughpermissionstobehere'unles