2007-05-07
每天一剂Rails良药之Authentication
关键字: Rails Authentication
今天我们来看看Rails怎么处理登录认证
虽然Rails有很多登录认证的插件,但是我们可以自己动手丰衣足食
1,db/migrate/001_add_user_table.rb
2,app/models/user.rb
3,app/controllers/admin_controller.rb
4,app/views/sign_form.rhtml
我们也可以将check_authentication方法放到application.rb里面,供其他Controllers使用
虽然Rails有很多登录认证的插件,但是我们可以自己动手丰衣足食
1,db/migrate/001_add_user_table.rb
class AddUserTable < ActiveRecord::Migration
def self.up
create_table :users do |t|
t.column :username, :string
t.column :password_salt, :string
t.column :password_hash, :string
end
end
def self.down
drop_table :users
end
end
2,app/models/user.rb
class User < ActiveRecord::Base
validates_uniqueness_of :username
def password=(pass)
salt = [Array.new(6){rand(256).chr}.join].pack("m").chomp
self.password_salt, self.password_hash = salt, Digest::SHA256.hexdigest(pass + salt)
end
def self.authenticate(username, password)
user = User.find(:first, :conditions => ['username = ?', username])
if user.blank? || Digest::SHA256.hexdigest(password + user.password_salt) != user.password_hash
raise "Username or password invalid"
end
user
end
end
3,app/controllers/admin_controller.rb
class AdminController < ApplicationController
before_filter :check_authentication, :except => [:signin_form, :signin]
def check_authentication
unless session[:user]
session[:intended_action] = action_name
redirect_to :action => :signin_form
end
end
def signin
session[:user] = User.authenticate(params[:username], params[:password]).id
redirect_to :action => session[:intended_action]
end
def signout
session[:user] = nil
redirect_to home_url
end
end
4,app/views/sign_form.rhtml
<html>
<head>
<title>Signin for Admin Access</title>
</head>
<body>
<%= start_form_tag :action => "signin" %>
<label for="username">Username:</label>
<%= text_field_tag "username" %><br/>
<label for="password">Password:</label>
<%= text_field_tag "password" %><br/>
<%= submit_tag "Sign in" %>
<%= end_form_tag %>
</body>
</html>
我们也可以将check_authentication方法放到application.rb里面,供其他Controllers使用
评论
iigm
2007-09-05
没看明白
hideto
2007-08-12
错误提示说了,把signin_form.rhtml放到app/views/user/目录下
danielking
2007-08-12
我把signin_form.rthml放在了views的根目录,就提示这个了:
No such file or directory - ./script/../config/../app/views/user/signin_form.rhtml
怎么回事?
No such file or directory - ./script/../config/../app/views/user/signin_form.rhtml
怎么回事?
发表评论
- 浏览: 612367 次
- 性别:

- 来自: BJ

- 详细资料
搜索本博客
我的相册
screenshot
共 1 张
共 1 张
最近加入圈子
最新评论
-
深入了解Java ClassLoader ...
当我对字节码编译不知所措的时候,发现了这个帖子 谢谢楼主,目前正在学习ASM C ...
-- by ytzhsh -
Rails里如何结合Exceptio ...
收藏了,小工具,好东西.
-- by yangzhihuan -
使用coderay和railscasts ...
不错,很爽,如果能显示成textmate那样的就好了。
-- by carlosbdw -
Axis2快速上手指南
看得很累,希望楼主写个HelloWorld.谢谢
-- by zznj1123 -
使用coderay和railscasts ...
javaeye自己用的是什么highlight什么的吗?
-- by qichunren






评论排行榜