草庐IT

alloc_on_stack

全部标签

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-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

ruby-on-rails - Ruby on Rails 和 Twitter OAuth 的测试策略

我正在开发一个利用twitteroauth的应用程序,但在试图弄清楚如何测试twitteroauth时遇到了障碍。特别是尝试使用Cucumber和Webrat/Selenium来测试功能——注册/登录过程中的某些步骤在用户是否授予对应用程序的oauth访问权限等方面表现不同。有没有人在他们的RubyonRailsCucumber功能(或与此相关的任何其他测试框架)中成功模拟或stub部分或全部TwitterOAuth系统?任何帮助将不胜感激。 最佳答案 OP已经一年多了,但我最近发现这篇关于使用TwitterAuth和Cucumbe

ruby-on-rails - 如何限制 Ruby 中的 Markdown 语法?

我希望使用Ruby库(例如Maraku)在RailsCMS评论系统中实现Markdown。或Kramdown.我需要限制用户可以提交哪些Markdown功能。在此系统中,不允许用户插入图像、html或执行任何繁重的编辑,但强调和超链接是可以的。本质上,我希望创建类似于thisTextilefilter的东西,但对于Markdown语法。 最佳答案 在Markdown转换之后,我一直在使用第二个步骤来使用sanitizegem清理数据.它基于白名单且非常可配置,您可以轻松实现您的目标。为了节省您的时间,这是我的文本格式化程序模块,希望