草庐IT

gitlab_rails

全部标签

ruby-on-rails - 在 Rails 中的何处设置跟踪(永久)cookie?

我正在尝试跟踪“匿名”用户的操作,并在他们注册后最终将其与他们的帐户相关联。我想我会通过设置永久cookie来做到这一点。我最好的选择是在ApplicationController中包含以下内容:classApplicationController这是正确的方法还是有更好的解决方案? 最佳答案 看起来不错,永久性cookie在未来(20年左右)过期,所以只要用户不手动删除它,您就应该能够跟踪他。我在很多地方都使用了这样的结构,而且效果很好。如果您包含要通过此操作加载的内容(典型的跟踪像素),您甚至可以让它在外部着陆页上运行。

ruby-on-rails - 使用 constantize 在 ruby​​ 中远程执行代码

当使用contantize时,我正试图解决ruby​​/rails中的远程代码执行漏洞。我知道能够向服务器提供任何类名可能存在潜在危险,但我想知道这本身是否危险。例如,如果RailsController代码看起来像这样(即在实例化对象上执行硬编码方法):klass=params[:class].classify.constantizeklass.do_something_with_id(params[:id])ifklass.respond_to?('do_something_with_id')此代码易受攻击吗?还是只能结合指定要在类上调用的方法? 最佳答案

ruby-on-rails - attr_internal 是做什么用的

我是ruby​​onrails的新手,在浏览rails代码时我发现了attr_internal:response_bodyattr_internal:action_nameattr_internal:formats它是什么,它有什么作用?为什么他们将attr_internal用于响应主体或Action名称的Action分派(dispatch)? 最佳答案 需要注意的是Rails提供了这个attr_internal来防止子类化时的名称冲突。因此,当创建attr_internal:variable读写实例方法时,后者由@_variabl

ruby-on-rails - Rails 4 路由错误 : No Route Matches [POST]

我在学习Rails4时正在做一个小练习,但在尝试更新对象时遇到路由错误。我不断收到错误消息:没有路由匹配[POST]"/movies/1/edit"但看不到我的代码哪里不正确:我的电影_controller.rbclassMoviesController"Yourmoviewassaved!"elserender"new"endenddefedit@movie=Movie.find(params[:id])enddefupdate@movie=Movie.find(params[:id])if@movie.update_attributes(params[:movie])redirec

ruby-on-rails - 当我尝试创建用户时,rails 说 ActionController::InvalidAuthenticityToken

已更新:问题已解决我只需要将protect_from_forgery放在UsersController中。感谢大家。rails4.0.2当我尝试在users表中创建新记录时,我在浏览器中收到此消息:ActionController::InvalidAuthenticityTokeninUsersController#createActionController::InvalidAuthenticityToken但它发生在Chrome(32.0.1700.107)和Opera(12.16)浏览器中。在Firefox(27.0.1)和IE10.0.13中一切正常。也许这并不重要,但我不得不

ruby - 如何在 Roo (Rails) : invalid byte sequence in UTF-8 中编码 csv 文件

我正在尝试上传一个csv文件,但收到UTF-8中的无效字节序列错误。我正在使用“roo”gem。我的代码是这样的:defupload_results_csvfilespreadsheet=MyFileUtil.open_file(file)header=spreadsheet.row(1)#THISLINERAISESTHEERROR(2..spreadsheet.last_row).eachdo|i|row=Hash[[header,spreadsheet.row(i)].transpose]......endclassMyFileUtildefself.open_file(file

ruby-on-rails - Rails 使用 Symbol 与 String 作为 params hash 中的键

如果我们使用字符串作为哈希键,Ruby需要计算字符串并查看它的内容(并计算其上的哈希函数)并将结果与​​已存储的键的(哈希)值进行比较在哈希中。如果我们使用一个符号作为散列键,则暗示它是不可变的,因此Ruby基本上可以将对象ID的(散列函数)与键的(散列)对象ID进行比较已经存储在哈希中。(快得多)。但问题在于Railsparams,它是HashWithIndifferentAccess的实例,如果我们编写params[:some_key]它会转换:som​​e_key到'some_key'然后它会尝试在参数散列中查找键。line159defconvert_key(key)key.ki

ruby-on-rails - Curl::Error::Partial File Error: 传输部分文件错误

我正在尝试在Rails控制台中执行以下代码:ce=Curl::Easy.new("http://www.homestolove.com.au/bathroom-profile-fresh-approach-2391")ce.verbose=truece.perform但我收到以下错误。谁能建议如何解决这个问题?看起来这个url返回响应的速度很慢。在文件传输完成之前,我们可以做些什么来阻止连接终止吗?*Addinghandle:conn:0x95f3210*Addinghandle:send:0*Addinghandle:recv:0*Curl_addHandleToPipeline:l

ruby-on-rails - rails/minitest 不为选择的测试加载 fixture

我的测试是使用固定装置编写的,我正在慢慢重构它们以使用工厂。一旦我重构了一个测试类以不使用固定装置,我就不想为该类加载固定装置。有没有办法做到这一点?或者我是否坚持要么为所有内容加载它们,要么什么都不加载?对于上下文,这是我现在的灯具设置方式:classActiveSupport::TestCaseRake::Task["db:fixtures:load"].execute...end 最佳答案 将fixtures放入test/fixtures/users.yml然后您可以将它们包含在您需要的地方,例如spec_helper#spe

ruby-on-rails - 在 Rails 上验证有限状态机(使用 AASM)

我正在使用AASMbyRubyist为AR对象构建4步向导。根据对象的状态,需要进行不同的验证。根据对象在特定转换时的状态来验证对象的最明智方法是什么? 最佳答案 使用:if选项和with_options将它们捆绑在一起。classPostproc{|r|r.signup_step>2}do|o|o.validates_presence_of:titleo.validates_presence_of:yeahendend显然,您应该在if-proc中具体写什么取决于您的实现。 关于rub