Ruby on rails 用户在rails中注册时创建会话

Ruby on rails 用户在rails中注册时创建会话,ruby-on-rails,Ruby On Rails,嗨 我对rails应用程序(2.3.10)中的注册功能有一些疑问 在我的视图/users/new.html.erb中 <div id="signup_form" style="display:none;" class="login-drpdwn "> <% form_for :user, :url => users_path do |f| -%> <%= error_messages_for 'user' %><br/>

我对rails应用程序(2.3.10)中的注册功能有一些疑问

在我的视图/users/new.html.erb中

<div id="signup_form" style="display:none;" class="login-drpdwn ">
  <% form_for :user, :url => users_path do |f| -%>
    <%= error_messages_for 'user' %><br/>
    <div>
      <p> Enter your  name </p>
      <%= f.text_field :name, :class => "text_box" %>
      <p> Enter your login name </p>
      <%= f.text_field :login, :class => "text_box" %>
      <p> Email ID</p>
      <%= f.text_field :email, :class => "text_box" %>
      <p> Password</p>
      <%= f.password_field :password, :class => "text_box" %>
      <p> Confirm your password</p>
      <%= f.password_field :password_confirmation, :class => "text_box" %>
      <div class="textalign_right">
        <input type="submit"  value="Submit"  class="submit_button rounded_corner"/>
      </div>
    </div>
  <% end %>
</div>
在我的用户模型中

before_save :encrypt_password
attr_protected :id, :password_salt
attr_accessor :password, :password_confirmation

def self.authenticate(email, password)
  user = find_by_email(email)
    if user && user.password_hash == BCrypt::Engine.hash_secret(password, user.password_salt)
  user
  else
    nil
  end
end

def encrypt_password
  if password.present?
    self.password_salt = BCrypt::Engine.generate_salt
    self.password_hash = BCrypt::Engine.hash_secret(password, password_salt)
  end
end
在我的会话控制器中-创建方法

def create
  @current_user = User.find_by_login(params[:login].downcase)
  if @current_user.blank? || params[:password] !=  @current_user.password_hash
    @current_user = nil
    render :action => "new"
  else
    session[:user_id] = @current_user.id
    session[:close_time] = 1800.seconds.from_now

    if @current_user.last_login.nil?
      @login = LastLogin.new
      @login.user_id = @current_user.id
      @login.login_at = Time.now
      @login.save
    else
      @login = @current_user.last_login
      @login.last_at = @login.login_at
      @login.login_at = Time.now
      @login.login_count += 1
      @login.save
    end

    if session[:return_to]
      redirect_to session[:return_to], :protocol => USE_PROTOCOL
      session[:return_to] = nil
    else
    end
  end
end
当我提交注册页面时,将创建用户,但不会创建会话 因此,它并不像在blogs controller中所需的filter:login\u之前那样直接指向blogs/主页

如何解决这个问题 我的代码没有包含经过身份验证的系统行

session[:id] = @current_user.id 会话[:id]=@current\u user.id
我应该在哪里插入该行?/修改Create方法中的第7行。因此,一般来说,使用预定义的会话[:id]而不是会话[:user\u id] session[:id] = @current_user.id