ruby-on-rails – 使用设计确认页面显示用户密码

我正在尝试在Devise邮件程序发送的确认页面显示用户密码.确认页面页面

Welcome test0@test.com!

You can confirm your account email through the link below:

Confirm my account

但是,我希望有

Welcome test0@test.com!

Your password is currently DASADSADS

You can confirm your account email through the link below:

Confirm my account

如何在视图中访问用户对象?我是否需要使用自定义控制器覆盖邮件控制器?如果是这样,我如何判断当前邮件方法是什么(尝试查看文档但找不到任何线索)?

我注意到在视图中使用了@email和@resource.我可以使用其中任何一个以未散列的形式访问当前密码吗?

请注意,我使用user.find(1).send_confirmation_instructions手动发送此电子邮件

解决方法

虽然可以做到这一点,但我会强烈反对这样做.专门使用散列密码,因此无法轻松重新创建密码.将原始密码传回给用户将导致它以纯文本形式发回,这有点违背了整个目的.此外,用户不应该已经知道他们的密码(毕竟他们输入了两次)?!?

为此,您需要在注册创建操作中捕获原始(未散列)密码,并在该点发送电子邮件(传递密码).您可以通过覆盖sign_up方法来执行此操作 – 您可以在初始化程序中执行此操作:

class Devise::RegistrationsController < DeviseController
  def sign_up(resource_name,resource)
    sign_in(resource_name,resource)
    resource.unhashed_password = resource_params[:password]
    resource.send_confirmation_instructions
  end
end

或者,你可以从Devise :: RegistrationsController派生一个新的控制器并在那里放置这个覆盖代码(推荐的方法 – 但是,然后再次,不建议这整个操作).您需要为此工作添加unhashed_pa​​ssword访问器:

class User < ActiveRecord::Base
  attr_accessor :unhashed_password
end

然后您可以更新您的确认视图(在app / views / devise / mailer / confirmation_instructions.html.erb)以包含以下内容

<p>Your password is currently <%= @resource.unhashed_password %></p>

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...