jjzjj

ruby-on-rails - 设计自定义登录表单

有什么方法可以将Devise身份验证器指向我的自定义登录表单?标准的、无样式的表单不可用(缺少字段,提交时抛出异常,实际上让我的运行时崩溃了一次。)而且不好看。我有一个100%可用的表单,它实际上可以让人们登录,但如果出现错误,则会显示标准表单,也没有错误消息。类似于“当被要求提供登录表单时,呈现/views/sys/login.html.erb,并在错误时返回到该View并输入错误消息”注意:我已经从另一个问题尝试了以下内容devise_for:users,:path=>'',:path_names=>{:sign_in=>"system/login",:sign_out=>"log

ruby-on-rails - 在 Rails 3 中自定义设计错误消息?

我正在使用设计来处理身份验证。总的来说我喜欢它,但我想稍微自定义一下错误显示。现在我有以下观点。error">"text"%>但是当邮件出现问题时,显示的信息如下:isinvalid。这对用户来说不是很友好,但我找不到设置此消息的位置。它似乎不在devise.en.yml中,但也许我忽略了一些东西。知道在哪里可以自定义错误消息吗?谢谢! 最佳答案 您可以在以下位置的区域设置文件中配置错误消息:/config/locales/devise.en.yml它应该有类似下面的代码,您可以根据自己的喜好轻松修改:en:errors:messa

ruby-on-rails - 请求规范中的 stub 身份验证

我正在寻找做this的方法但在要求规范。我需要登录和注销double或instance_double来设计而不是实际的ActiveModel/ActiveRecord。通过使用wiki页面中的代码:moduleRequestSpecHelpersdefsign_in(user=double('user'))ifuser.nil?allow(request.env['warden']).toreceive(:authenticate!).and_throw(:warden,{:scope=>:user})allow(controller).toreceive(:current_user)

ruby-on-rails - 使用 Devise 登录后测试重定向

为此,我遵循了Devisegithub页面的建议:http://github.com/plataformatec/devise/wiki/How-To:-Redirect-to-a-specific-page-on-successful-sign-in现在效果很好,但是您现在如何测试您是否有这种行为? 最佳答案 有两种方法可以在单元级别测试它,一种是在继承应用程序Controller的Controller中编写测试。代码看起来像it"shouldredirecttopage_xafterloggedin"dosign_in:user

ruby-on-rails - 使用具有两个 Devise 用户模型和不同身份验证方法的登录表单

我正在构建一个站点,该站点必须支持通过LDAP进行的身份验证,以及仅在站点中管理的“本地”用户。目前我有以下Devise模型:classUserDevise正在为其中的每一个生成独立的路由,即/local_users/sign_in和/ldap_users/sign_in。这并不理想,用户不需要知道他们是哪种类型的用户,所以我想将它们统一为一种形式,使用一组登录/注销URL。我已经查看了一些关于如何执行此操作的解决方案,但它们似乎依赖于模型具有相同的Devise配置或相同的身份验证方法这一事实。我发现的此类问题的唯一其他在线示例是此Google网上论坛帖子:https://groups

ruby-on-rails - 在 View 中设计解锁按钮

这可能非常简单,我忽略了它。我正在使用设计可锁定功能,我想创建一个按钮,管理员可以检查该按钮以解锁锁定的用户。Devise有一个名为unlock_access!的模型方法.我试图在用户的Controller方法中使用View中的按钮调用它。观看次数:=link_to('unlock',user_unlock_path(user),method::post,class:'button-xs')unlessuser==current_userusers_controller.rb:defunlockuser=User.find(params[:id])user.unlock_access!

iphone - 设计和 Rails 3 中的 http 身份验证

我有一个使用deviseonrails3的应用程序。我想启用http身份验证,以便我可以从iPhone应用程序向我的网络应用程序进行身份验证。如何从我的iPhone应用程序进行身份验证以进行设计?这安全吗?还是我应该进行不同的身份验证? 最佳答案 从设计的角度来看,您有3个选择:1)使用基本的http身份验证:您的iPhone应用程序有一个secretkey-这是在您的iPhone应用程序代码中烘焙的-用于对网络应用程序的每个请求进行身份验证。Google搜索:“设计基本的http身份验证”2)您可以通过在您的iPhone应用程序中

ruby-on-rails - 注销前更新 current_user 时收到 "Attempted to update a stale object: User"异常

我在我的用户模型上启用了乐观锁定,以处理我代码库各个部分中可能发生的冲突。但是,我遇到了意外冲突,我不知道如何处理它,因为我不知道是什么原因造成的。我正在使用Devisegem进行身份验证,并且正在使用before_logout方法来重置安全token...classSessionsController:createbefore_filter:before_logout,:only=>:destroydefafter_login#logictosetthesecuritytokenenddefbefore_logoutcurrent_user.update(security_token

ruby-on-rails - 检查用户是否已在设计中注销

我正在尝试检查管理员是否在Rspec测试中注销。但是通常的signed_in?从rspec中看不到方法,它不是RSpecDeviseHelpers的一部分。这就是我所拥有的before(:each)do@admin=FactoryGirl.create(:administrator)sign_in@adminendit"shouldallowtheadmintosignout"dosign_out@admin#@admin.shouldbe_nil#@admin.signed_in?.shouldbe_falseadministrator_signed_in?.shouldbe_fal

ruby-on-rails - 在 Devise 中,last_sign_in_at 的用途是什么?

Devise中的标准用户列是last_sign_in_at,当current_sign_in_at更新时,它保存current_sign_in_at的先前值。last_sign_in_at是否对Devise的核心功能或模块功能有任何实用性,还是只是为了方便起见? 最佳答案 last_sign_in_at是用户在当前session之前登录的日期和时间,即current_sign_in_at。如果他们还没有登录或者这是他们的第一次session,它将是nil。更好的名称可能是previous_sign_in_at,因为这不是他们上次(当