草庐IT

session_time

全部标签

ruby-on-rails - 使用 ruby​​ mechanize 在浏览器中存储登录 session cookie

我正在尝试登录网站并通过Rails操作重定向到安全页面。我的代码看起来像这样。defredirect_to_externalagent=Mechanize.newpage=agent.get('http://example.com/home.asp')login_form=page.form_with(:name=>"loginForm")login_form.login='username'login_form.password='password'agent.submit(login_form)#cookies=agent.cookie_jar.store.map{|i|i}#ne

ruby - 使用 Time.zone 使用 strptime 解析时间

我正在尝试使用Ruby2.0中的Time类解析日期时间。我不知道如何解析日期并在指定时区获取它。我使用Time.zone.parse解析我第一次调用Time.zone的日期并将其设置为指定时区。在下面的示例中,我设置了区域但它不影响strptime,我已经尝试执行Time.zone.parse(date)但我无法解析它如下所示的日期。Time.zone="CentralTime(US&Canada)"#=>"CentralTime(US&Canada)"irb(main):086:0>Time.strptime("08/26/201303:30PM","%m/%d/%Y%I:%M%p"

ruby - ActiveJob::SerializationError - 不支持的参数类型:Time/DateTime

我正在使用Rails5和ActiveJob来处理后台任务。我正在尝试将使用as_json序列化的对象传递给我的工作,但我收到以下错误:ActiveJob::SerializationError(Unsupportedargumenttype:Time):ActiveJob::SerializationError(Unsupportedargumenttype:DateTime):我知道ActiveJob不会接受Time/DateTime对象,因为一些排队系统不处理这些类型。所以我要序列化的对象如下:card=Card.first=>#当我运行时:card.as_json=>{"id"=

ruby - Rack::Session::Pool 与 Sinatra

我有一个使用enable:sessions构建的Sinatrawebapp,我使用session[:mything]访问我的session数据。我现在想在服务器端存储数据(即使用基于数据库的session),但我不知道如何使用Rack::Session::Pool,这似乎是我需要使用的东西。我如何着手转换我的网络应用程序以与Pool一起使用?我知道我需要添加行useRack::Session::Pool接下来会发生什么?—提前致谢!编辑:这是一个使用基于cookie的session的示例:require'rubygems'require'sinatra'enable:sessionsg

ruby - 时间 :Class after requiring active_support/time_with_zone 的未定义方法 `zone`

我在使用Ruby2.2.1并安装了active_support4.2,所以我想使用Time.zone.parse('2007-02-1015:30:45')如此处所述:http://api.rubyonrails.org/classes/ActiveSupport/TimeWithZone.html但即使在需要active_support和active_support/time_with_zone之后,我觉得Time.zone仍然不起作用。观察:2.2.1:002>require"active_support"=>true2.2.1:003>Time.zoneNoMethodError

ruby-on-rails - Capistrano 部署 :migrate and db:migrate run all migrations every time

因此,我正在使用rails(ruby1.9.3p392、rails3.2、sqlite3db)并尝试将无处不在的博客教程代码部署到“生产”服务器(apache、passenger、ubuntu)。我的deploy.rb看起来像这样:require'bundler/capistrano'require'rvm/capistrano'load'deploy/assets'set:rvm_ruby_string,ENV['GEM_HOME'].gsub(/.*\//,"")set:rvm_type,:userset:user,'blah'set:application,'railsTest'

ruby - Time.advance 记录在哪里?

在网络上四处寻找,我发现RubyTime类有Time#advance。这在哪里记录?我在RubyAPI文档中没有看到它的提及here.API文档的搜索功能表明在任何地方都没有名为“advance”的方法。尽管如此,在IRB中......>>t=Time.now=>ThuMar0516:08:57-08002009>>t.advance:months=>1=>SunApr0516:08:57-07002009另一件让我感到困惑的事情......在时间类的文档中,它说的第一件事是“实现time.rb库文档中描述的时间类的扩展。”他们的意思是“time.rb库实现了对这个类的扩展吗?”我想也

ruby-on-rails - 阅读 Rails session secret 的最佳方式是什么?

我想以编程方式访问Railssessionsecret(我正在使用它来生成登录token)。这是我想出的:ActionController::Base.session.first[:secret]这将返回sessionsecret。但是,每次调用ActionController::Base.session时,它都会向数组中添加另一个条目,因此您最终会得到如下内容:[{:session_key=>"_new_app_session",:secret=>"totally-secret-you-guys"},{},{},{},{},{},{},{},{},{},{},{},{}]我觉得这不太

ruby-on-rails - 如何将 Rails session cookie 过期时间设置为 "session"

我对Rails中不在表面上的部分不是很有经验。我想要的只是有一个sessioncookie,其过期时间设置为session,这样当用户离开浏览器或其他任何东西时它就会过期。作为安全措施。 最佳答案 默认情况下,cookie是sessioncookie。通过在config/initializers/session_store.rb中提供选项散列,您可以完全控制cookie。选项与Rack::Session::Cookie(seedocs)相同。因此,例如,对于特定的到期日期,您可以提供:expire_after。如果您使用Devise

ruby - Sinatra 不会在 Chrome 上通过重定向保持 session

Sinatra没有在Chrome上通过重定向保留我的session。它正在创建一个全新的session,我正在丢失我以前的所有session数据。举个例子(类似于theSinatradocs),我正在做这样的事情:enable:sessionsget'/foo'dosession[:user_id]=123session[:session_id]#"ABC",forexampleredirectto('/bar')endget'/bar'do#thisis"DEF"whenrespondingtoChrome(wrong),#but"ABC"whenrespondingtoFirefo