Ruby on rails(十六)-登录

来源:岁月联盟 编辑:zhu 时间:2009-01-09

  现在我们的购物车程序为两种用户提供了服务,一类是普通用户,一类是管理员。两类用户分别有不同的功能。上次我们又实现了添加用户的功能,这次我们来实现登录的功能。

  1.     给login_controller添加login方法。

  上次使用rails的命令行生成的login_controller中已经包含了login方法,下面修改该方法的内容:

def login
  
if request.get?
  
session[:user_id] = nil
  
@user = User.new
  
else
  
@user = User.new(params[:user])
  
logged_in_user = @user.try_to_login
  
if logged_in_user
  
session[:user_id] = logged_in_user.id
  
redirect_to(:action => "index")
  
else
  
flash[:notice] = "Invalid user/password combination"
  
end
  
end
  
end

  2.     在上面的方法中看到调用了user.try_to_login方法,下面我们就要在user.rb文件中添加该方法:

def self.login(name, password)
  
hashed_password = hash_password(password || "")
  
find(:first,
  
:conditions => ["name = ? and hashed_password = ?",
  
name, hashed_password])
  
end
  
def try_to_login
  
User.login(self.name, self.password)
  
end

  在这个方法里我们判断hash_password是不是匹配。

  3.     现在我们来添加一个index页面,用在用户登录后显示订单信息。在viewslogin目录下,添加一个index.rhtml文件,内容如下:

<% @page_title = "Administer your Store" -%>
  
<h1>Depot Store Status</h1>
  
<p>
  
    Total orders in system: <%= @total_orders %>
  
</p>
  
<p>
  
    Orders pending shipping: <%= @pending_orders %>
  
</p>

  4.     当然我们还要在login_controller里再添加一个action:index,内容入下:

def index
  
@total_orders = Order.count
  
@pending_orders = Order.count_pending
  
end

  里面又调用了Order.count 和Order.count_pending,就还要修改order.rb文件,内容如下:

def self.count_pending
  
count("shipped_at is null")
  
end

  5.     最后我们还差一个login的页面,下面创建一个login.rhtml,放在viewslogin目录下,其内容为:

<%= form_tag %>
  
    <table>
  
           <tr>
  
                  <td>User name:</td>
  
                  <td><%= text_field("user", "name") %></td>
  
           </tr>
  
           <tr>
  
                  <td>Password:</td>
  
                  <td><%= password_field("user", "password") %></td>
  
           </tr>
  
           <tr>
  
                  <td></td>
  
                  <td><input type="submit" value=" LOGIN " /></td>
  
           </tr>
  
    </table>
  
<%= end_form_tag %>

  6.     OK了,下面来看看结果,在浏览器中访问http://localhost:3003/login/login(其中的端口号根据自己的配置决定。),应该看到下面的结果:

Ruby on rails开发从头来(windows)(十六)-登录

  输入的用户名或密码不正确的情况:

Ruby on rails开发从头来(windows)(十六)-登录

  登录成功后:

Ruby on rails开发从头来(windows)(十六)-登录