我是Kohana的新手。我在 Kohana 3.2 中使用默认路由,即
Route::set('default', '(<controller>(/<action>(/<id>)))')
->defaults(array(
'controller' => 'admin',
'action' => 'login',
));
我的控制器如下:
<?php defined('SYSPATH') or die('No direct script access.');
class Controller_Admin extends Controller{
public function __construct($request, $response) {
parent::__construct($request, $response);
}
public function action_login(){
$session = Session::instance();
if($session->get('admin_id')){
//Session is set / Logged in
$this->request->redirect('users/list');
exit();
}
if($_POST){
$user = ORM::factory('admin');
$post = Validation::factory($_POST)
->rule('username', 'not_empty')
->rule('password', 'not_empty');
if(!$post->check()){
Message::error($post->errors('admin'));
}
else{
$objUserDetails = $user->checkCredentials($_POST);
if($objUserDetails->id){
//Valid username and password
$session->set('admin_id', $objUserDetails->id);
$this->request->redirect('users/list');
exit();
}
else{
Message::error("Invalid username or password");
$this->request->redirect('admin/login');
exit();
}
}
}
$this->response->body(new View(
'login',
array('title'=>'Administrator login')
));
}
public function action_logout(){
$session = Session::instance();
$session->delete('admin_id');
$session->destroy();
$this->request->redirect('admin/login');
}
}
我的 .htaccess如下:
# Turn on URL rewriting
RewriteEngine On
# Installation directory
RewriteBase /
# Protect hidden files from being viewed
<Files .*>
Order Deny,Allow
Deny From All
</Files>
# Protect application and system files from being viewed
RewriteRule ^(?:application|modules|system)\b.* index.php/$0 [L]
# Allow any files or directories that exist to be displayed directly
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
# Rewrite all other URLs to index.php/URL
RewriteRule .* index.php/$0 [PT]
当我打字http://localhost
时,它工作正常。但是当我输入http://localhost/admin/login
或http://localhost/admin/logout
显示 404 错误。
请帮忙。