国产精品一区二区精品_久久小视频_天堂va在线观看_99久久夜色精品国产亚洲96_日本手机在线视频_av成人免费

當(dāng)前位置:首頁(yè) > 網(wǎng)站舊欄目 > 學(xué)習(xí)園地 > 設(shè)計(jì)軟件教程 > 每天一劑Rails良藥之Authentication

每天一劑Rails良藥之Authentication
2010-01-14 07:03:49  作者:  來源:
今天我們來看看Rails怎么處理登錄認(rèn)證
雖然Rails有很多登錄認(rèn)證的插件,但是我們可以自己動(dòng)手豐衣足食

1,db/migrate/001_add_user_table.rb
Java代碼 復(fù)制代碼
  1. class AddUserTable < ActiveRecord::Migration   
  2.   def self.up   
  3.     create_table :users do |t|   
  4.       t.column :username, :string   
  5.       t.column :password_salt, :string   
  6.       t.column :password_hash, :string   
  7.     end   
  8.   end   
  9.   
  10.   def self.down   
  11.     drop_table :users   
  12.   end   
  13. end  


2,app/models/user.rb
Java代碼 復(fù)制代碼
  1. class User < ActiveRecord::Base   
  2.   validates_uniqueness_of :username   
  3.   
  4.   def password=(pass)   
  5.     salt = [Array.new(6){rand(256).chr}.join].pack("m").chomp   
  6.     self.password_salt, self.password_hash = salt, Digest::SHA256.hexdigest(pass + salt)   
  7.   end   
  8.   
  9.   def self.authenticate(username, password)   
  10.     user = User.find(:first, :conditions => ['username = ?', username])   
  11.     if user.blank? || Digest::SHA256.hexdigest(password + user.password_salt) != user.password_hash   
  12.       raise "Username or password invalid"  
  13.     end   
  14.     user   
  15.   end   
  16. end  


3,app/controllers/admin_controller.rb
Java代碼 復(fù)制代碼
  1. class AdminController < ApplicationController   
  2.   before_filter :check_authentication, :except => [:signin_form, :signin]   
  3.   
  4.   def check_authentication   
  5.     unless session[:user]   
  6.       session[:intended_action] = action_name   
  7.       redirect_to :action => :signin_form   
  8.     end   
  9.   end   
  10.   
  11.   def signin   
  12.     session[:user] = User.authenticate(params[:username], params[:password]).id   
  13.     redirect_to :action => session[:intended_action]   
  14.   end   
  15.   
  16.   def signout   
  17.     session[:user] = nil   
  18.     redirect_to home_url   
  19.   end   
  20.   
  21. end  


4,app/views/sign_form.rhtml
Java代碼 復(fù)制代碼
  1. <html>   
  2.   <head>   
  3.     <title>Signin for Admin Access</title>   
  4.   </head>   
  5.   <body>   
  6.     <%= start_form_tag :action => "signin" %>   
  7.       <label for="username">Username:</label>   
  8.       <%= text_field_tag "username" %><br/>   
  9.       <label for="password">Password:</label>   
  10.       <%= text_field_tag "password" %><br/>   
  11.       <%= submit_tag "Sign in" %>   
  12.     <%= end_form_tag %>   
  13.   </body>   
  14. </html>  

我們也可以將check_authentication方法放到application.rb里面,供其他Controllers使用

安徽新華電腦學(xué)校專業(yè)職業(yè)規(guī)劃師為你提供更多幫助【在線咨詢
主站蜘蛛池模板: 国产毛片精品一区二区 | 成人免费精品视频 | 日本美女一区 | 日韩三极| 欧美伦理一区 | 亚洲综合色自拍一区 | 亚洲三级电影在线观看 | 久久99综合 | h片免费网站 | 久久久久亚洲av成人毛片韩 | 国产大片网站 | 国产高清美女一级a毛片久久 | 黄色一级毛片在线观看 | 亚洲成人综合视频 | 免费在线观看黄 | 久久99深爱久久99精品 | 黄色三级电影在线观看 | 婷婷在线综合 | 国产精品久久久久免费a∨大胸 | 日日日日日 | 久久九九 | 亚洲综合电影 | 好吊在线视频 | 免费三级电影网站 | 91精品久久久久久久久入口 | 中文字幕日韩一区 | caoporn国产一区二区 | 成人在线中文字幕 | 九九久久这里只有精品 | 日韩专区中文字幕 | 在线中文天堂 | 国产精品久久久久久 | 欧美www视频| 国产精品久久欧美久久一区 | 夜夜久久| 日韩av中文在线 | 桃色五月 | 欧美日激情 | 国产一区二区三区视频在线播放 | 爱爱视频网址 | 人人人人干 |