gpt4 book ai didi

ruby-on-rails - Rails 设计重置密码不起作用

转载 作者:行者123 更新时间:2023-12-04 05:47:33 26 4
gpt4 key购买 nike

我在 rails 3 应用程序中使用设计。我已经设计了完全工作但是“忘记密码”功能已决定停止工作。当我输入一个电子邮件地址并单击“向我发送重置说明”按钮时,我将被重定向到登录页面,该页面显示一条闪现通知,提示请先登录。我还发现“向我发送重置说明”正在尝试访问 http://0.0.0.0:3000/users/password .我以前有这个工作,现在它决定停止工作。我不认为它与任何形式的授权(如 ACL9)有任何关系。有没有人遇到过同样类似的问题。是否有任何可能的解决方案来解决这个问题。

设计/Password_controller.rb

class Devise::PasswordsController < ApplicationController
prepend_before_filter :require_no_authentication
include Devise::Controllers::InternalHelpers

access_control do
allow all
end

# GET /resource/password/new
def new
build_resource({})
render_with_scope :new
end

# POST /resource/password
def create
self.resource = resource_class.send_reset_password_instructions(params[resource_name])

if successful_and_sane?(resource)
set_flash_message(:notice, :send_instructions) if is_navigational_format?
respond_with({}, :location => after_sending_reset_password_instructions_path_for(resource_name))
else
respond_with_navigational(resource){ render_with_scope :new }
end

rescue => e;
puts e.backtrace;
raise e;
end

# GET /resource/password/edit?reset_password_token=abcdef
def edit
self.resource = resource_class.new
resource.reset_password_token = params[:reset_password_token]
render_with_scope :edit
end

# PUT /resource/password
def update
self.resource = resource_class.reset_password_by_token(params[resource_name])

if resource.errors.empty?
flash_message = resource.active_for_authentication? ? :updated : :updated_not_active
set_flash_message(:notice, flash_message) if is_navigational_format?
sign_in(resource_name, resource)
respond_with resource, :location => redirect_location(resource_name, resource)
else
respond_with_navigational(resource){ render_with_scope :edit }
end
end

protected

# The path used after sending reset password instructions
def after_sending_reset_password_instructions_path_for(resource_name)
new_session_path(resource_name)
end

end


  ProjectRails::Application.configure do
# Settings specified here will take precedence over those in config/application.rb

# In the development environment your application's code is reloaded on
# every request. This slows down response time but is perfect for development
# since you don't have to restart the webserver when you make code changes.
config.cache_classes = false

# Log error messages when you accidentally call methods on nil.
config.whiny_nils = true

# Show full error reports and disable caching
config.consider_all_requests_local = true
config.action_view.debug_rjs = true
config.action_controller.perform_caching = false

# Don't care if the mailer can't send
config.action_mailer.raise_delivery_errors = true

# Print deprecation notices to the Rails logger
config.active_support.deprecation = :log

# Only use best-standards-support built into browsers
config.action_dispatch.best_standards_support = :builtin

config.action_mailer.perform_deliveries = true
config.action_mailer.raise_delivery_errors = true

#SMTP

#SMTP

config.action_mailer.default_url_options = { :host => "0.0.0.0:3000" }
config.action_mailer.delivery_method = :smtp
config.action_mailer.smtp_settings = { :address => "smtp.example.example.ltd.uk",
:user_name => "example.service@example.co.uk",
:password => "1Plonker",
:authentication => "login" }

end


config/intializers/devise

config.mailer_sender = "Project@example.co.uk"

最佳答案

运行 rake 路由以检查它是否路由到正确的位置。还要检查您的 view/password/new.html.erb 并检查 URL 是否路由到您的登录路径而不是 :url => password_path(resource_name) 因为这是一个常见问题。这应该可以解决您的问题。也改变你的

:location => after_sending_reset_password_instructions_path_for(resource_name))


:location => (whatever the login path is) 

:-)

关于ruby-on-rails - Rails 设计重置密码不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7633891/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com