rails實(shí)現(xiàn)注冊(cè)登錄模塊

準(zhǔn)備工具

ruby v2.2.6
rails v5.0.0.1

開整

  1. 新建項(xiàng)目 rails new blog
  2. 進(jìn)入目錄 cd blog
  3. 在Gemfile添加
gem "rails-i18n" #用于本地化
gem "slim-rails" #使用slim代替erb模板
gem "bcrypt" #用于密碼的校驗(yàn)(不可少)
  1. bundle install
  2. 創(chuàng)建用戶注冊(cè)model rails g model User name password password_digest[1]
#app/models/user.rb
class User < ActiveRecord::Base 
  +  has_secure_password #用于密碼的校驗(yàn)
end 
  1. 創(chuàng)建控制器 rails g controller user new index new create
  #app/controllers/users_controller.rb
class UserController < ApplicationController
  def new
    @user=User.new
  end

  def index
  end

  def create
    @user=User.create(user_params)
      if @user.save
        redirect_to :sessions_new #用戶信息保存成功后,跳轉(zhuǎn)到登錄頁(yè)面
      else
        render "new"
      end
  end
  
  private
  def user_params #用于過濾傳入的參數(shù)
    #password_confirmation是用來校對(duì)密碼是否相同,同時(shí)為密碼加密
    params.require(:user).permit(:name,:password,:password_confirmation)    
  end
end
  1. 修改views的視圖文件[2]
/! app/views/users/index.html.slim
h1
  = link_to "注冊(cè)", new_user_path
 /! app/views/users/new.html.slim
 h1 注冊(cè)
 - if @user.errors.any?
  ul
  - @user.errors.full_messages.each do |message|
    li= message
= form_for @user, url: :users_create do |f|
  p
    = f.label "用戶名:"
    = f.text_field :name
  p
    = f.label "密碼:"
    = f.password_field  :password
  p
    = f.label "確認(rèn)密碼:"
    = f.password_field  :password_confirmation
  p
    = f.button "提交"
    |  
    = link_to "返回", user_index_path
  1. 修改路由文件(routes.rb)
#config/routes.rb
Rails.application.routes.draw do
  get 'user/new'
  get 'user/index'
 -  get 'user/create'  
 +  post 'user/create'
end
  1. 數(shù)據(jù)庫(kù)遷移 rake db:migrate
  2. 啟動(dòng)服務(wù) rails s,讓我來看看成果如何
    Paste_Image.png

    Paste_Image.png

    Paste_Image.png

    Paste_Image.png

樣子挫一些,但功能還算實(shí)現(xiàn)了,這里提示全是中文的,是用到rails-i18n進(jìn)行了本地化,可以參考Rails的本地化設(shè)置全過程

  1. 創(chuàng)建登錄功能控制 rails g controller sessions new create
  2. 修改session_controller.rb
class SessionsController < ApplicationController
  def new
    @user = User.new
  end

  def create
    user=User.find_by(name: user_params[:name]).try(:authenticate, user_params[:password])

    if user
      render plain: sprintf("歡迎,#{user.name}")
    else
      flash.now[:login_error]="無效的用戶名或密碼!"
      render "new"
    end
  end

  private
  def user_params
    params.require(:session).permit(:name, :password)
  end
end
  1. 修改session的顯示
 /! app/views/applicants/new.html.erb
 h1 登錄
 
 - if flash[:login_error]
     p=flash[:login_error]

 = form_for :session, url: :sessions_create do |f|
     p
      =f.label "用戶名:"
     =f.text_field :name
    p
      =f.label "密碼:"
     =f.password_field :password
   p
     =f.button "登錄"
     = '  '
     = link_to "返回", user_index_path
/! app/views/users/index.html.slim
h1
  = link_to "注冊(cè)", new_user_path
  |  
  = link_to "登錄", session_new_path
  1. 修改路由
 Rails.application.routes.draw do
  get 'sessions/new'
 -  post 'sessions/create'
 + post 'sessions/create'

  get 'user/new'
  get 'user/index'
  post 'user/create'

 end
  1. 查檢登錄頁(yè)面
Paste_Image.png

Paste_Image.png
Paste_Image.png
Paste_Image.png

  1. 這里用的name,password都是String類型,所以可以省略數(shù)據(jù)類型。 ?

  2. 這里的豎線后要加兩個(gè)空格(空格多了也沒用,在最后也只顯示一個(gè)空格,html的特性,要想加的多可以用&nbsp),create.html.slim可以不用管。 ?

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

推薦閱讀更多精彩內(nèi)容