当前位置:首页 > 网站旧栏目 > 学习园地 > 设计软件教程 > 每天一剂Rails良药之Authentication

每天一剂Rails良药之Authentication
2010-01-14 07:03:49  作者:  来源:
今天我们来看看Rails怎么处理登录认证
虽然Rails有很多登录认证的插件,但是我们可以自己动手丰衣足食

1,db/migrate/001_add_user_table.rb
Java代码 复制代码
  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代码 复制代码
  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代码 复制代码
  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代码 复制代码
  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使用

安徽新华电脑学校专业职业规划师为你提供更多帮助【在线咨询