Ruby on Rails實現(xiàn)最基本的用戶注冊和登錄功能的教程
在 Rails 實現(xiàn)用戶注冊和登錄功能是非常方便的,比如可以使用 Devise 這類實現(xiàn)了完整功能的 gem 擴展包。也可以使用 Rails 自帶的 has_secure_password 來自已打造。下面就是嘗試使用 has_secure_password 來實現(xiàn)用戶注冊和登錄功能。
準備工作
創(chuàng)建項目:
rails new user_login
has_secure_password 中加密的功能需要用到 bcrypt ,所以需要在項目中啟用 bcrypt gem 包。進入項目目錄,修改 Gemfile 文件如下內(nèi)容:
# Use ActiveModel has_secure_password gem 'bcrypt', '~> 3.1.7'
保存后退出,執(zhí)行 bundle install 命令安裝新啟用的 gem 包。
創(chuàng)建用戶模塊
操作和管理用戶信息需要先創(chuàng)建保存用戶的數(shù)據(jù)表和模型:
rails g model user name:string password_digest:string
password_digest 這個字段是用來保存加密混淆后的密碼串的,必須提供并且不能更改成其它名稱,否則無法正常使用 has_secure_password 提供的功能。
然后在用戶模塊中引入 has_secure_password 功能:
# app/models/user.rb class User < ActiveRecord::Base has_secure_password end
創(chuàng)建用戶數(shù)據(jù)表:
rake db:migrate
實現(xiàn)注冊功能
創(chuàng)建一個 Applicant(申請者) 控制器用來處理用戶注冊:
rails g controller applicants new create
applicants 控制器提供了兩個方法:
- new: 用來處理注冊界面
- create: 用來保存注冊信息
上面命令創(chuàng)建的控制器方法,默認使用的都是 get 請求。保存注冊信息的 create 方法使用的是 post 請求。所以需要到 config/routes.rb 中修改如下內(nèi)容:
post 'applicants/create'
完成注冊控制器功能:
# app/controllers/applicants_controller.rb class ApplicantsController < ApplicationController def new @user = User.new end def create @user = User.create(user_params) if @user.save redirect_to :sessions_new else render "new" end end private def user_params params.require(:user).permit(:name, :password, :password_confirmation) end end
完成注冊界面功能:
<!-- app/views/applicants/new.html.erb --> <h1>注冊</h1> <% if @user.errors.any? %> <ul> <% @user.errors.full_messages.each do |message| %> <li><%= message %></li> <% end %> </ul> <% end %> <%= form_for @user, url: :applicants_create do |f| %> <p> <%= f.label :name %> <%= f.text_field :name %> </p> <p> <%= f.label :password %> <%= f.password_field :password %> </p> <p> <%= f.label :password_confirmation %> <%= f.password_field :password_confirmation %> </p> <p><%= f.button "提交" %></p> <% end %>
這樣就簡單的實現(xiàn)了注冊功能。
實現(xiàn)登錄功能
創(chuàng)建一個 Session(會話) 控制器用來處理用戶登錄和退出:
rails g controller sessions new create
這里在 sessions 控制器上默認創(chuàng)建了 2 個方法:
- new: 用來處理登錄界面
- create 用來處理登錄流程
跟注冊一樣,需要修改 create 的默認路由為 post:
# config/routes.rb post 'sessions/create'
完成會話控制器的功能:
# app/controllers/sessions_controller.rb class SessionsController < ApplicationController def new end def create user = User.find_by(name: user_params[:name]).try(:authenticate, user_params[:password]) if user render plain: sprintf("welcome, %s!", user.name) else flash.now[:login_error] = "invalid username or password" render "new" end end private def user_params params.require(:session).permit(:name, :password) end end
完成會話登錄界面:
<!-- app/views/sessions/new.html.erb --> <h1>登錄</h1> <% if flash[:login_error] %> <p><%= flash[:login_error] %></p> <% end %> <%= form_for :session, url: :sessions_create do |f| %> <p> <%= f.label :name %> <%= f.text_field :name %> </p> <p> <%= f.label :password %> <%= f.password_field :password %> </p> <p><%= f.button "登錄" %></p> <% end %>
版權(quán)聲明:本站文章來源標注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學習參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。