jjzjj

access-control

全部标签

ruby-on-rails - RunTimeError:Rspec 2.10.1 中的 ActionController::RackDelegation for rails 3.1.4 应用程序 Controller

在我们的rails3.1.4应用程序中,rspec用于测试应用程序Controller中的公共(public)方法require_signin。这是require_signin方法:defrequire_signinif!signed_in?flash.now.alert="Loginfirst!"redirect_tosignin_pathendend这是rspec代码:it"shouldinvokerequire_signinforthosewithoutlogin"docontroller.send(:require_signin)controller{shouldredirec

ruby-on-rails - Rails Controller 丢失 JSON 字符串中的换行符

这里有点碰壁。我正在尝试将包含换行符的字符串(\n,由JSON.stringify转换为\u000a)作为JSON对象的一部分发送到Rails应用程序:{"bob":{"id":46,"notes":"foo\u000abar\u000abaz"}}这是通过网络传输的,\u000a转义为%5Cu000a:http://localhost/bobs/46?draft=true&%7B%22bob%22%3A%7B%22id%22%3A46%2C%22notes%22%3A%22foo%5Cu000abar%5Cu000abaz%22%7D%7D=但是当请求到达Rubyland时,换行符消

ruby-on-rails - 在 Controller 中 stub 一个实例变量

我正在使用rspec1.3.2来测试看起来像这样的Controller操作:defaction_foo...@bar.can_do_something?...end我正在尝试stub@bar(假设它是Bar类的一个实例)实例变量,但我无法做到。我认为如果我可以访问any_instance那么我可以执行Bar.any_instance.stub(:can_do_something?)但这在我使用的rspec版本中不可用。是否有另一种方法来访问和stub@bar?以下均无效:@bar.stub(:can_do_something?)controller.instance_variable_

ruby-on-rails - 重命名 Rails Controller 的简单方法

这个问题在这里已经有了答案:Howtorenamerailscontrollerandmodelinaproject(8个答案)关闭7年前。有重命名Controller的简单方法吗?我知道的唯一方法是手动完成或生成一个新的Controller,将代码移至旧Controller并销毁旧Controller。似乎必须有一种编程方式来执行此操作。

ruby-on-rails - Rails 和 attr_accessible : is there a way to raise an exception if a non-mass-assignable attribute is mass-assigned?

如果尝试批量分配attr_accessible不允许的属性,是否有办法让Rails引发错误?这在开发中会很方便,可以提醒我为什么我Shiny的新模型不起作用,也有助于登录生产环境以检测恶意事件。我正在使用Rails2.3.8,但可能很快就会迁移到3。 最佳答案 从Rails3.2开始,这不再需要monkeypatching——rails现在提供了这种行为。将其放入development.rb和test.rb:config.active_record.mass_assignment_sanitizer=:strict

ruby-on-rails - Activeadmin 渲染 'new' 在尝试覆盖创建 Controller 方法时给出无法找到没有 ID 的用户

我正在尝试在activeadmin中创建一个页面,用户可以在其中创建新的用户帐户。我正在使用以下代码覆盖我的用户模型的默认创建方法。当我尝试呈现new页面时,出现错误Couldn'tfindUserwithoutanID。为什么在尝试重新呈现new操作时会出现此错误?ActiveAdmin.registerUserdopermit_paramsdopermitted=[:email,:encrypted_password]permitted日志:StartedGET"/admin/users/new"for127.0.0.1at2014-03-0921:34:35-0500Proces

ruby-on-rails - rails : accessing field value from model method

刚开始学习Rails(三)。我正在努力寻找如何做一些可能完全微不足道的事情:从该模型的方法内部访问模型实例字段的值。以我为例:defformal_name@title+""+@forename+""+@surnameend所有三个@properties(它们都是数据库中表上的字段)都返回nil。他们不应该。令人难以置信的是,http://guides.rails.info/并未讨论如何访问字段,google什么也找不到。顺便说一句,我来自Django,这里的东西很明显。 最佳答案 @语法用于实例变量,这些实例变量(例如)在Contr

ruby-on-rails - 如何将 Controller 包含在 Ruby on Rails gem 中?

我正在尝试为一个开源项目做贡献,我需要一个Controller来处理需要提交的几个表单。我在gem中名为app/controllers/gemname/my_controller.rb的目录中创建了这些Controller。但是,当我尝试访问Controller时,它似乎没有被加载(我得到一个名称错误,就好像我输入了NonExistentController之类的东西)。如何使用gem加载我的Controller?谢谢! 最佳答案 假设您的gem名为MyGem,并且您有一个名为SuperController的Controller,您

ruby - Rails 渲染 Controller 中的部分和布局

我正在覆盖设计注册Controller的创建操作。我有两种注册表格,个人或公司,公司有一个名为company_form的字段设置为true以区分这两种表格。在表单验证后,我希望呈现正确的表单(以前无论我使用什么表单,它都会返回默认表单)。我遇到了一个问题,即只渲染了部分(很明显,因为我只渲染了部分),但我还需要渲染布局/应用程序文件。classRegistrationsControllerifresource.company_formrenderpartial:'shared/company_signup_form'elserenderpartial:'/shared/individu

ruby-on-rails - 如何正确捕获 Controller 操作中的异常?

有如下代码:defindex@posts=User.find_by(login:params[:user_id]).postsend如您所见,如果没有用户登录,此代码会生成异常(无指针异常)。我怎样才能捕获这个异常并正确处理它?我知道如何在Ruby中捕获异常,但我想知道如何以良好的Rails风格来做。同样的问题可能发生在不同的Controller中——也许我应该创建一个Action包装器,捕获异常并呈现500错误? 最佳答案 最简单的方法是使用ApplicationController的rescue_from:classApplic