- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
为新帐户设计电子邮件确认发送得很好,但重新确认对我不起作用。我有:
# config/initializers/devise.rb
config.reconfirmable = true
当我登录(确认或未确认)并转到设置更改我的电子邮件地址时,它会保存更改,但不会发送重新确认电子邮件。
我正在使用 mongoid。我将字段 :unconfirmed_email 添加到用户模型(以及确认所需的所有其他字段。正如我所说的确认有效。)。我的用户更新操作非常简单:
# registrations_controller
def update
current_user.update_attributes(user_update_params)
redirect_to current_user
end
我的参数包括 :email 字段。
当我更新电子邮件时,它没有被复制到 unconfirmed_email 字段。由于某种原因,该字段仍然为零。
有什么我可能遗漏的想法吗?我正在使用所有最新版本的 Rails、Devise、Mongoid...
这让我抓狂。我继续并恢复到 Devise 自己的注册 Controller :
# registrations_controller.rb
class Users::RegistrationsController < Devise::RegistrationsController
end
甚至暂停了我自己的用户编辑文档,所以它现在使用基本的 Devise Edit 表单。
仍然,它在注册时发送确认就好了,但不发送重新确认。
我在 devise.rb 初始值设定项中有这个:
config.reconfirmable = true
config.allow_unconfirmed_access_for = 2.days and confirmation_sent_at = Time.now
我的数据库字段:
# user.rb
field :confirmation_token, type: String
field :confirmed_at, type: Time
field :confirmation_sent_at, type: Time
field :unconfirmed_email, type: String
我有这些 Devise 设置:
devise :database_authenticatable, :registerable,
:recoverable, :rememberable, :trackable,
:confirmable,
:omniauthable, :omniauth_providers => [:facebook]
unconfirmed_email 永远不会改变,无论我多久更新一次电子邮件。电子邮件实际上得到了更新,如果没有得到确认,这是不合逻辑的。
我错过了什么?我该如何调试?
最佳答案
我刚遇到同样的问题。
为了调试,我重写了 before_update
和 after_commit
(或 after_update
for mongoid)的测试方法,如下所示:
# User.rb
def reconfirmation_required?
result = super
debugger
result
end
def postpone_email_change?
result = super
debugger
result
end
当 debugger
语句暂停执行时,我打印出 reconfirmation_required?
的 bool 表达式中的每一项。和 postpone_email_change?
在控制台中查看它们是否返回了预期值。
在我的例子中,我发现无论电子邮件是否更改,email_changed
始终为 false。 30 秒后我发现 email_changed
在 User.rb
中被覆盖,并且 git blame
显示另一个开发人员几个月前做了这个 hack 来跳过发送导入帐户时的确认信....删除 hack 可以再次确认。
希望这条信息对您有所帮助。祝调试顺利!
引用:Confirmable
源代码 - https://github.com/plataformatec/devise/blob/master/lib/devise/models/confirmable.rb
关于ruby-on-rails - 设计可重新确认不发送,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36379697/
TCP header 上的 32 位确认字段,比如 x告诉另一台主机“我收到了所有字节,直到并包括 x-1,现在期待来自 x 和 on 的字节”。在这种情况下,接收方可能已经收到了一些更多字节,比如
我正在使用 PyCharm 2020.2.3 不知不觉中我点击了下图中的复选框 现在,即使我的代码正在调试中,点击运行也会终止调试并开始运行代码。如何将其恢复为未选中状态?谢谢。 PS:我的“允许并行
我想知道何时使用 RabbitMQ 和 Spring Boot 接受 (ack) 或不接受 (nack) 消息。 我想将消息发送到队列(通过交换)并检查队列是否已接受该消息。实际上我想发送到两个不同的
我一直在寻找一种方法让用户确认 票在分配给他们之后。不知道有没有 这是一个内置功能,或者如果有一个插件 将为用户创建一个状态/按钮以接受票证 在它被放入队列之后。我希望 从附近的售票窗口看到类似的东西
我正在构建一个应用程序以通过 Xbee API 与 Xbee 模块通信。 目前我有一些工作,但它相当简单并且有很多限制。 Sub processPackets() ' this runs as its
我有一个复选框,更改后会自动发布。 自动发布对于两者(选中和未选中)都适用,但我想在每个事件发生之前弹出一个对话框进行确认。 到目前为止,当选中该复选框时,弹出框就会起作用。 但当取消选中该复选框时,
当我使用 UIGestureRecognizer ,例如,当用户向右滑动时,我想要一个 UIAlertView询问他是否真的要进行向右滑动的 Action 。 我曾尝试这样做,但没有成功。 最佳答案
我有一个 asp:CheckBoxList,我想显示一条警告消息仅在使用 jquery 取消选中复选框时。 $('.chklist').click( function () {
我想知道有什么可能的方法来确定我们的推送消息是否最终从 APNS 服务器传送。我已经想出了一些信息,如下所述 APNS 正在发送接受推送请求的响应代码,并可能给出错误代码(如果有)。例如:如果您的有效
我有此页面,我正在尝试确认输入文本字段中的日期与当前日期。如果输入字段中的日期晚于当前日期,则需要出现确认框以确认他们输入了正确的日期。因此,“确定”按钮需要完成数据提交,“取消”按钮需要将它们返回到
我有一个功能: function placeOrder(price, productList) { var bulletinBoardItem = Number(productList.box
我不明白为什么即使我点击“否”,这个confirm()调用也会被触发。你能告诉我我做错了什么吗? $('.deleteButton').livequery('click',function(){
我目前正在使用 dotmailer 生成一个新表单(简单的文本框和提交按钮),自动将电子邮件地址添加到 dotmailer 地址簿。 当有人提交电子邮件地址时 - 他们可以被带到网页。 我一直在尝试
这是不起作用的代码...它只是删除表单而不先提示。 $(".delete").click(function () { if(confirm('You honestly want to dele
我在我的程序中使用 aprgeparse 创建一个参数,允许用户从 amazon s3 存储桶中删除文件。我以这种方式创建它: parser.add_argument("-r", "--remove"
我正在努力学习 puppeteer 操作。我已经成功编写了登录页面和一些导航的脚本。然后我让它点击一个按钮。该页面抛出一个 window.confirm,我希望我的脚本接受它以继续下一步,但我不知
某网站实现了一个第三方插件,提示用户在删除前进行确认。 confirmDelete: function (event) { var go_ahead = confirm("Are you su
我想在 primefaces 的选择/取消选择复选框上显示确认对话框。我试过了 但它不起作用,因为 selectBooleanCheckBox 不可确认。是否有解决此问题的解决方法? 最
我们已经从 TFS 下载了一个项目,在恢复 Nuget 包后,我们收到以下错误: Error 5 The "ValidatePackageReferences" task could not
我有两个单独的 ul 列表:列表 A 和列表 B 由于 jQuery UI 插件,它们都可以排序。 我正在开发的项目的用户希望在项目从一个列表移动到另一个列表时确认操作,但在同一列表内移动时则不需要。
我是一名优秀的程序员,十分优秀!