2017-04-26 17 views
0

私のテナントごとにセットアップの一部として新しいデータベースを作成していますが、dbは正常に作成されましたが、約5分、他のコントローラメソッド(admin_listコントローラとmanage_packageメソッド)を呼び出すことができません。これは私のコントローラのコードです:コードシニターで別のコントローラメソッドを呼び出せません

<?php 
 
class login extends CI_Controller 
 
{ 
 
    var $data; 
 

 
    function __construct() { 
 
     parent::__construct(); 
 
\t \t $this->load->helper('cookie'); 
 
\t \t require_once(APPPATH.'controllers/admin_list.php'); 
 

 
\t \t $is_admin_logged_in = $this->admin_init_elements->admin_logged_in_status(); 
 
\t \t global $USER; 
 
\t \t if($is_admin_logged_in == TRUE){ 
 
\t \t \t redirect('home'); 
 
\t \t \t //; 
 
     } 
 

 
     //populate viewfor header/footer elements 
 
     
 
     $this->admin_init_elements->init_elements('N'); 
 
\t \t $this->load->model('mod_login'); 
 
\t \t 
 
    } 
 

 
public function save_userinput() 
 
    { 
 
     //code goes here 
 
     // for example: getting the post values of the form: 
 
     $form_data = $this->input->post(); 
 
     // or just the username: 
 
     $username = $this->input->post("username"); 
 
\t echo $username; 
 
\t // $this->admin_list->manage_package(); 
 
     $this->load->dbforge(); 
 

 
\t 
 
    if ($this->dbforge->create_database($username)) 
 
{ 
 
    try{ 
 
     $current_database = $username; 
 
     $this->db->database = $current_database; 
 
\t 
 
    $this->db->close(); 
 
    $config['hostname'] = "localhost"; 
 
    $config['username'] = "root"; 
 
    $config['password'] = ""; 
 
    $config['database'] = $current_database; 
 
    $config['dbdriver'] = "mysql"; 
 
    $config['dbprefix'] = $username; 
 
    $config['pconnect'] = FALSE; 
 
    $config['db_debug'] = TRUE; 
 
    $config['cache_on'] = FALSE; 
 
    $config['cachedir'] = ""; 
 
    $config['char_set'] = "utf8"; 
 
    $config['dbcollat'] = "utf8_general_ci"; 
 
    $this->load->database($config); 
 
    $fields = array(
 
         'id' => array(
 
               'type' => 'INT', 
 
               'constraint' => 11, 
 
               'unsigned' => TRUE, 
 
               'auto_increment' => TRUE 
 
             ), 
 
\t \t \t \t \t \t 'home_bg' => array(
 
               \t 'type' => 'VARCHAR', 
 
               'constraint' => '200', 
 
             ), 
 
         'login_bg' => array(
 
               'type' => 'VARCHAR', 
 
               'constraint' => '200', 
 
             ), 
 
         'other_bg' => array(
 
               'type' =>'VARCHAR', 
 
               'constraint' => '200', 
 
                
 
             ), 
 
         'uploaded_on' => array(
 
               'type' => 'DATE', 
 
                
 
             ), 
 
       ); 
 

 
    $this->dbforge->add_field($fields); 
 
    $this->dbforge->add_key('id', TRUE); 
 
    $this->dbforge->create_table('pr_backgrounds', TRUE); 
 

 

 

 
$fields = array(
 
         'id' => array(
 
               'type' => 'BIGINT', 
 
               'constraint' => 15, 
 
               'unsigned' => TRUE, 
 
               'auto_increment' => TRUE 
 
             ), 
 
\t \t \t \t \t \t 'username' => array(
 
              'type' => 'VARCHAR', 
 
               'constraint' => '255', 
 
\t \t \t \t \t \t \t \t \t \t \t \t 'default' => '[email protected]', 
 
             ), 
 
         'userpass' => array(
 
               'type' => 'VARCHAR', 
 
               'constraint' => '255', 
 
\t \t \t \t \t \t \t \t \t \t \t \t 'default' => '65e1b655a6d6f4cbed20554d3b52521a743afdc0', 
 
             ), 
 
         'email' => array(
 
               'type' =>'VARCHAR', 
 
               'constraint' => '255', 
 
               'default' => '[email protected]', 
 
             ), 
 
         'departmentid' => array(
 
                'type' => 'BIGINT', 
 
               'constraint' => 15, 
 
               'default' => '1', 
 
                
 
             ), 
 
\t \t \t \t \t \t 'userroleid' => array(
 
                'type' => 'BIGINT', 
 
               'constraint' => 15, 
 
               'default' => '4', 
 
                
 
             ), 
 
\t \t \t \t \t  'managerid' => array(
 
               'type' =>'VARCHAR', 
 
               'constraint' => '255', 
 
                'default' => '10', 
 
             ), 
 
\t \t \t \t \t \t 'userlevel' => array(
 
                'type' => 'INT', 
 
               'constraint' => 11, 
 
               
 
                
 
             ), 
 
\t \t \t \t \t \t 'branchid' => array(
 
                'type' => 'INT', 
 
               'constraint' => 11, 
 
               'default' => '2', 
 
             ), 
 
\t \t \t \t \t \t 'is_global' => array(
 
                'type' => 'TINYINT', 
 
               'constraint' => 4, 
 
               
 
               'default' => '0', 
 
             ), 
 
\t \t \t \t \t \t 'registrationtime' => array(
 
                'type' => 'INT', 
 
               'constraint' => 10, 
 
               
 
                
 
             ), 
 
\t \t \t \t \t \t 'timemodified' => array(
 
               'type' => 'BIGINT', 
 
               'constraint' => 10, 
 
               
 
                
 
             ), 
 
\t \t \t \t \t  'modifierid' => array(
 
                'type' => 'BIGINT', 
 
                'constraint' => 15, 
 
               
 
                
 
             ), 
 
\t \t \t \t \t \t \t \t \t \t \t  'status' => array(
 
                'type' => 'TINYINT', 
 
                'constraint' => 1, 
 
               
 
                
 
             ), 
 

 
\t \t   'deleted' => array(
 
                'type' => 'TINYINT', 
 
                'constraint' => 1, 
 
               
 
                
 
             ), 
 
\t \t \t \t  'temppass' => array(
 
                'type' => 'VARCHAR', 
 
                'constraint' => 20, 
 
               
 
                
 
             ), 
 

 
\t \t \t \t \t  'temppassvalidtill' => array(
 
                'type' => 'BIGINT', 
 
               'constraint' => 15, 
 
               
 
                
 
             ), 
 
\t \t \t \t \t \t  'lastlogin' => array(
 
                'type' => 'BIGINT', 
 
               'constraint' => 10, 
 
               
 
                
 
             ), 
 
\t \t \t \t \t \t 'lastrefresh' => array(
 
                'type' => 'BIGINT', 
 
               'constraint' => 15, 
 
               
 
                
 
             ), 
 
\t \t \t \t \t \t \t \t 'lastloginip' => array(
 
                'type' => 'VARCHAR', 
 
               'constraint' => 20, 
 
               
 
                
 
             ), 
 
\t \t \t \t \t \t \t \t 'if_online' => array(
 
                'type' => 'INT', 
 
               'constraint' => 11, 
 
               
 
                
 
             ), 
 
\t \t \t \t \t \t \t \t 'pfield' => array(
 
                'type' => 'VARCHAR', 
 
               'constraint' => 255, 
 
               
 
                
 
             ), 
 
       ); 
 

 
    $this->dbforge->add_field($fields); 
 
    $this->dbforge->add_key('id', TRUE); 
 
    $this->dbforge->create_table('pr_users', TRUE); 
 

 

 
$sql = file_get_contents("assets/bizzlatestdb.sql"); 
 

 
/* 
 
Assuming you have an SQL file (or string) you want to run as part of the migration, which has a number of statements... 
 
CI migration only allows you to run one statement at a time. If the SQL is generated, it's annoying to split it up and create separate statements. 
 
This small script splits the statements allowing you to run them all in one go. 
 
*/ 
 

 
$sqls = explode(';', $sql); 
 
array_pop($sqls); 
 

 
foreach($sqls as $statement){ 
 
    $statment = $statement . ";"; 
 
    $this->db->query($statement); 
 
\t 
 
} 
 

 

 

 
    } 
 
\t 
 
\t catch(Exception $e){ 
 
     echo "This name already exists in our database , Please choose another company name"; 
 
\t die; 
 
    } 
 
    $this->admin_list->manage_package(); 
 

 
    } 
 

 

 
     // then do whatever you want with it :) 
 

 
    } 
 
    function index(){ 
 
    
 
\t \t 
 
\t \t $this->load->view('login', $this->data); 
 

 
     
 
    } 
 

 
\t  
 
} 
 
    
 
?>

+0

REFERE [本](http://stackoverflow.com/questions/14165895/how-to-load-a-controller-from-another-controller- in-codeigniter)Answer –

+0

あなたの実際の質問は何ですか?また、http://stackoverflow.com/help/how-to-ask –

+0

を読んでいることを確認してください。このリンクを試す必要があります。http://stackoverflow.com/questions/9494492/codeigniter-extending-multiple-controllers –

答えて

3

あなたはCodeigniter2にライブラリとしてコントローラをロードすることができます。しかし、私はCodeigniter3で可能とは思わない。ライブラリとして

負荷コントローラ:

$this->load->library('../controllers/controller_name'); 

# Calling Methdod 

$this->controller_name->method_name(); 
+0

は空白画面に$ this-> load-> library( '../ controllers/admin_list')を追加してください。 – sunshine

+0

使用しているCodeigniterのバージョンは2または3ですか? –

+0

codeigniter version 2 – sunshine

関連する問題