草庐IT

Set-Cookie

全部标签

ruby - 是否有一个 Rack 中间件可以在没有 cookie 的情况下使用 session ?

Rack自带的session管理中间件都是基于cookie来识别用户的。由于我正在开发一个api,我宁愿将sessionID作为查询字符串参数显式传递。查看代码库,似乎没有考虑这个用例,因为所有session中间件都从一个公共(public)类扩展,读取/写入cookie。所以我的问题是-是否有一个项目维护替代的Rack中间件或Rack内置中间件的猴子补丁,这将允许我维护查询字符串上的sessionID,而不是cookie存储? 最佳答案 Rack可以使用自定义sessionID项代替cookie:require'rack/sess

ruby-on-rails - 可以将哈希存储在 cookie 中吗?

有人知道我是否可以在cookie中放入哈希值吗?像这样:cookies[:test]={:top=>5,:middle=>3,:bottom=>1}谢谢 最佳答案 我会考虑序列化散列来存储它。然后反序列化它以检索它。当您序列化哈希时,结果将是一个编码字符串。可以对该字符串进行解码以取回原始对象。您可以为此使用YAML或JSON。两者都在Ruby中得到很好的支持。一个YAML示例require"yaml"cookies[:test]=YAML::dump{a:1,b:"2",hello:"world"}#=>"---\n:a:1\n:

ruby - capybara 与 cucumber |获取 cookie

我试图在Cucumber步骤中获取cookie值:步骤定义When/^Ilogin$/do#codetologinendThen/^cookiesshouldbeset$/docookies[:author].should_notbe_nilendControllerclassSessionsController但它不起作用:结果expected:notnilgot:nil在RSpec示例中,一切正常:Controller规范require'spec_helper'describeSessionsControllerdodescribe'create'doit'setscookies'

arrays - Set in ruby​​ 的优点

Set的主要优点似乎是保持独特的元素。但这可以在Array中轻松实现,array=[2,3,4]array|[2,5,6]#=>[2,3,4,5,6]我遇到的唯一明显特征(可能适用于少数用例)是,set1=[1,2,3].to_setset2=[2,1,3].to_setset1==set2#=>true[1,2,3]==[2,1,3]#=>false既然Array有各种相关的功能和操作,我什么时候以及为什么要使用Set?有很多比较Array和Set的链接,但我还没有遇到Set的重要应用。 最佳答案 当然,无论您可以使用Set做什么

ruby - 如何使用( ruby ) Rack 中间件组件设置 cookie?

我正在为需要有条件地设置cookie的Rails应用编写Rack中间件组件。我目前正在尝试设置cookie。通过谷歌搜索,这似乎应该可行:classRackAppdefinitialize(app)@app=appenddefcall(env)@status,@headers,@response=@app.call(env)@response.set_cookie("foo",{:value=>"bar",:path=>"/",:expires=>Time.now+24*60*60})[@status,@headers,@response]endend它不会给出错误,但也不会设置coo

ruby-on-rails - rails : Where does new_*something*_path variable get set up?

我为“消息”创建了一个脚手架,并且new_message_path和edit_message_path(用于link_to's)都已设置,但现在我已经创建了app/views/messages/sent.html.erb,我想做类似的内容,但我不知道该怎么做。我明白了undefinedlocalvariableormethod`sent_message_path'for# 最佳答案 这些方法是在定义路由时自动创建的,对于RESTful路由,它们遵循可预测的约定。运行“rakeroutes”是查看生成的所有路由的有用方法。我建议您阅读

ruby-on-rails - Rails(set_no_cache 方法)无法在 Safari 和 Opera 中禁用浏览器缓存

在使用Devise进行身份验证后,我发现其中存在一个安全漏洞,在用户注销后,session变量会被保留。这允许任何人按下后退按钮并访问已登录用户的上一个屏幕。我看了这些帖子Num1Num2Num3我将这些行添加到我的application_controllerbefore_filter:set_no_cachedefset_no_cacheresponse.headers["Cache-Control"]="no-cache,no-store,max-age=0,must-revalidate"response.headers["Pragma"]="no-cache"response.

ruby-on-rails - 如何从 ApplicationController (Rails) 访问 cookie

我想访问cookie,然后执行相同的操作,而不管操作或Controller如何。我不想编写一个从我的无数操作方法中的每一个调用的方法,因为除了痛苦之外,它不会产生非常敏捷的代码。我宁愿从application_controller.rb中的ApplicationController类(所有Controller类的父类(superclass))调用我的cookie处理方法。但是,在ApplicationController类的主体中调用cookies()会引发“未定义方法”错误。(我想cookies直到后来才被定义。)我能做什么?我是否应该覆盖ApplicationController的

ruby - 在类声明后设置类继承或在 const_set 类上设置类继承

如果之前已经定义了一个类,我如何告诉它从父类继承例如:classParent..endclassKlass..end现在我希望它继承自Parent我无法重新打开类并设置它,因为我会收到类不匹配错误classKlass具体来说,我试图找出如何在我通过Object.const_set创建的类上设置类继承klass=Object.const_set('Klass',Class.new)如何让Klass继承自Parent类? 最佳答案 无法更改已存在类的父类(superclass)。要指定您正在动态创建的类的父类(superclass),您

ruby - Sinatra/1.4.3 使用 Rack::Session::Cookie 警告

我的配置代码require'sinatra'#set:environment,:productionenable:sessionsenable:loggingsetrun:truecasewhenproduction?setport:8081whendevelopment?require'sinatra/reloader'require'better_errors'useBetterErrors::MiddlewareBetterErrors.application_root=__dir__enduseRack::Session::Cookie,key:'N&wedhSDF',doma