Codigniter'default_controller'无效

时间:2018-01-06 11:36:40

标签: php codeigniter

当连接'base_url'时,

浏览器显示许多重定向。

示例,当我输入“www.xxx.com”,然后编码工具显示错误!(到很多重定向)

但我输入“www.xxx.com/login”,显示登录控制器页面!我怎么了......?我想看默认控制器。但这不行......

这是我的codeigniter配置源。

    $config['base_url'] = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == "on") ? "https" : "http");
    $config['base_url'] .= "://" . $_SERVER['HTTP_HOST'];
    $config['base_url'] .= str_replace(basename($_SERVER['SCRIPT_NAME']), "", $_SERVER['SCRIPT_NAME']);

这是我的codeigniter路由源。

    $route['default_controller'] = 'login';
    $route['404_override'] = 'error404';
    $route['translate_uri_dashes'] = FALSE;
    $route['assets/(:any)'] = 'assets/$1';

结束,这是我的codeigniter登录控制器源。

    <?php
    defined('BASEPATH') OR exit('No direct script access allowed');

    class Login extends CI_Controller
    {
        private $menu = "login";
        function __construct()
        {
            parent::__construct();
        }

        function index()
        {
            $data['menu'] = $this->menu;
            $this->load->view('include/header', $data);
            $this->load->view('login/login');
            $this->load->view('include/footer');
        }
        function register()
        {
            $data['menu'] = $this->menu;
            $this->load->view('include/header', $data);
            $this->load->view('login/register');
            $this->load->view('include/footer');
        }

    }

最后这是我的.htaccess来源。

    <IfModule mod_rewrite.c>
     RewriteEngine On
     RewriteBase /
     RewriteCond $1 !^(index\.php|images|assets|captcha|data|include|uploads|robots\.txt)
     RewriteCond %{REQUEST_FILENAME} !-f
     RewriteCond %{REQUEST_FILENAME} !-d
     RewriteRule ^(.*)$ /index.php/$1 [L]
    </IfModule>

我不明白为什么default_controller不起作用!我指的是什么?感谢..: - (

1 个答案:

答案 0 :(得分:0)

我真的很抱歉。所有问题都从'钩子'开始! 我推荐“Auth”钩子。但是,当我改变我的域名时,我不会编辑我的钩子。 编辑域名时,一切正常。 谢谢你的评论。这真的是对我的建议。

这是我的'Auth.php'&lt;钩!

<?php
class Auth {
    function check_login() {
    $CI =& get_instance();
    isset($CI->session) OR $CI->load->library('session');

    $CI->session->has_userdata('user_name') OR
    $CI->session->set_userdata('user_name', 'guest');

    $username = $CI->session->userdata('user_name');

    if(!(strpos(current_url(), "authentication")) && 
       !(current_url() === "http://my_domain.com") && 
       !(current_url() === "http://my_domain.com/"))
    { 
       if($username==='guest' && 
          !(isset($CI->allowed_method) && 
           in_array($CI->router->method, $CI->allowed_method)))
       {
            redirect("/");
       }
    }
 }
}
?>