Rails devise сброс пароля не работает

#ruby-on-rails #ruby-on-rails-3 #devise

#ruby-on-rails #ruby-on-rails-3 #разработка

Вопрос:

Я использую devise в приложении rails 3. У меня полностью работает devise, однако функция «забыли пароль» решила перестать работать. Когда я ввожу адрес электронной почты и нажимаю кнопку «отправить мне инструкции по сбросу», я перенаправляюсь на страницу входа, на которой отображается флэш-уведомление с надписью «пожалуйста, войдите сначала». Я также обнаружил, что «пришлите мне инструкции по сбросу» пытается получить доступ 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"
  

Комментарии:

1. вставьте код passwords_controller

2. У вас есть devise :recoverable в вашей модели, да?

3. вы пробовали удалить access controll do portoin? если да, то вставьте также свой application_controller

4. Удаление контроля доступа откуда? Вот мой пирог для моего application_controller

5. pastie.org/private/dipskswt2hdauskwrjlcg

Ответ №1:

Запустите rake routes, чтобы проверить, что он маршрутизирует в правильное местоположение. Также проверьте свой view/password/new.html.erb и убедитесь, что URL перенаправляется на ваш путь входа в систему вместо:url => password_path(имя_ресурса), поскольку это распространенная проблема. Это должно решить вашу проблему. Также измените свой

 :location => after_sending_reset_password_instructions_path_for(resource_name))
  

Для

 :location => (whatever the login path is) 
  

🙂

Ответ №2:

Вы используете это среда разработки, верно? Вы проверили правильность следующего:

 # config/environments/development.rb

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

config.action_mailer.default_url_options = { :host => 'mydomain.com' }

# config/initializers/devise.rb
config.mailer_sender = "youremail@domain.com"
  

Комментарии:

1. И да, я запускаю это в разработке, и у меня есть то, что вы предложили

2. Вы должны добавить config.action_mailer.raise_delivery_errors = true config.action_mailer.perform_deliveries = true в свой файл development.rb.

3. Я включил это, см. Мой обновленный пост, содержащий полную разработку.rb