0

我最近创建了一种更改当前用户密码的方法,但是在保存记录后,我的 UserSession.find 返回 nil,我尝试通过编写 UserSession.new({...}).save 没有运气,任何关于如何解决这个问题?

这是我的代码,请注意通过 AJAX 请求运行(这是 UserSessionController 下的方法):

定义

 change_my_password
    #print "--------------RECORD: #{current_user_session.record.as_json}-------- #{current_user_session.user.as_json}"
    user = current_user
    user_email = user.email
    user_remember_me = user.remember_created_at
    response = {
      :success => false,
      :message_code => Extjs::MessageCodes::ERROR,
      :message => 'Si è verificato un errore',
      :total => 0,
      :root => []
    }
    if user.valid_password?(params[:old_password], true)
      user.password = params[:new_password]
      user.password_confirmation = params[:confirm_password]
      response[:message] = 'La nuova password e la conferma non coincidono o sono troppo brevi'
      if user.save
        response[:success] = true
        response[:message_code] = Extjs::MessageCodes::SUCCESS
        response[:message] = 'Password modificata con successo'
      end
    else
      response[:message] = 'La password precedente non coincide con quella attualmente in uso'
    end

    respond_to do |format|
      format.extjson { render :json => response }
    end
  end
4

2 回答 2

3

确保您没有将maintain_sessions参数设置为false,即:

acts_as_authentic do |c|
  c.maintain_sessions = false # change this to true.
end

或者

保存后手动更新会话:

user.send(:update_sessions)

或者

保存后重新创建会话:

UserSession.create(user)
于 2012-06-21T18:48:51.777 回答
0

实际上我没有找到解决这个问题的方法:我通过在更改密码后再次强制登录来解决(甚至增加了安全性,所以还不错)。

我认为 KandadaBoggu 的回答是正确的,但我测试了所有这些,但它们对我不起作用。

也许这是我的代码中有问题造成的问题,我真的不知道。目前我只是将其视为解决方案,因为它实际上适用于我的软件。

如果找到更好的答案,我很乐意标记它。

谢谢大家。

于 2012-06-26T02:17:35.297 回答