當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Debug::trace方法代碼示例

本文整理匯總了PHP中Debug::trace方法的典型用法代碼示例。如果您正苦於以下問題:PHP Debug::trace方法的具體用法?PHP Debug::trace怎麽用?PHP Debug::trace使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Debug的用法示例。


在下文中一共展示了Debug::trace方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: __construct

 public function __construct()
 {
     // Set Cookie Defaults
     $this->time = time() + 60 * 60 * 24 * 365;
     $this->cookie_path = "/";
     $this->cookie_domain = rtrim($_SERVER['HTTP_HOST'], '/');
     // Add trace for debugging
     \Debug::trace('Input class initiated successfully', __FILE__, __LINE__);
 }
開發者ID:Kheros,項目名稱:Plexis,代碼行數:9,代碼來源:Input.php

示例2: __construct

 function __construct()
 {
     $this->load = load_class('Loader');
     // Setup the databases and realm
     $this->DB = $this->load->database('DB');
     $this->RDB = $this->load->database('RDB');
     $this->realm = $this->load->realm();
     // Add trace for debugging
     \Debug::trace('Base model class initialized', __FILE__, __LINE__);
 }
開發者ID:Kheros,項目名稱:Plexis,代碼行數:10,代碼來源:Model.php

示例3: query

 /**
  * Run a query against the global MySQL connection.
  *
  * @param string $query
  * @param boolean $log
  * @return MySQL Result
  */
 function query($query, $log = false)
 {
     $res = mysql_query($query);
     $err = mysql_errno();
     self::$queryCount++;
     if ($err != 0) {
         Debug::trace("[QUERY] {$query}");
         Debug::critical("[ERROR] " . "I'm sorry, Dave, I'm afraid I can't do that. " . mysql_error());
         error_log($query);
         error_log(mysql_error());
     } elseif ($log) {
         Debug::trace("[QUERY] {$query}");
     }
     return $res;
 }
開發者ID:briancline,項目名稱:spire,代碼行數:22,代碼來源:database.php

示例4: __construct

 public function __construct()
 {
     // Add trace for debugging
     \Debug::trace('Initializing language class...', __FILE__, __LINE__);
     // Load the Input and Filesystem class'
     $this->Input = load_class('Input');
     $this->filesystem = load_class('Filesystem', 'Library');
     // Load our languages
     $this->scan_language_dirs();
     // Set the default language
     $this->default_language = load_class('Config')->get('default_language');
     // Set the default Language
     $this->selected_language();
     // Add trace for debugging
     \Debug::trace('Language class initiated successfully', __FILE__, __LINE__);
 }
開發者ID:Kheros,項目名稱:Plexis,代碼行數:16,代碼來源:Language.php

示例5: run

 /**
  * 執行某個行為
  * @param string $name 行為名稱
  * @param Mixed $params 傳人的參數
  * @return void
  */
 public static function run($name, &$params = null)
 {
     if (APP_DEBUG) {
         Debug::mark('behaviorStart');
     }
     // 實例化並執行
     // if($name == 'App\\Home\\Behaviors\\CheckSessionId') {
     $class = $name;
     // }
     // else {
     // 	$class = __NAMESPACE__ . '\\Behaviors\\' . $name;
     // }
     $behavior = new $class();
     $behavior->run($params);
     // 記錄行為的執行日誌
     if (APP_DEBUG) {
         Debug::mark('behaviorEnd');
         Debug::trace('Run ' . $name . ' Behavior [ RunTime:' . Debug::mark('behaviorStart', 'behaviorEnd', 6) . 's ]', '', 'INFO');
     }
 }
開發者ID:minowu,項目名稱:smartthink,代碼行數:26,代碼來源:Tag.php

示例6: delete

 public function delete($path, $files = array())
 {
     // Correct path
     $path = str_replace(array('/', '\\'), DS, $path);
     // Add trace for debugging
     \Debug::trace("Deleting file/folder '{$path}'", __FILE__, __LINE__);
     if (is_dir($path)) {
         // Make sure our path is correct
         if ($path[strlen($path) - 1] != DS) {
             $path = $path . DS;
         }
         // Check to see if we are just removing file or what :O
         if (!empty($files)) {
             foreach ($files as $f) {
                 // Attempt to delete the file, return false if even 1 fails
                 if (!$this->delete($path . $f)) {
                     return false;
                 }
             }
             // End of loop, return true
             return true;
         } else {
             // Remove the whole dir
             return $this->remove_dir($path);
         }
     } else {
         return $this->delete_file($path);
     }
 }
開發者ID:Kheros,項目名稱:Plexis,代碼行數:29,代碼來源:Filesystem.php

示例7: findRoute

 protected function findRoute()
 {
     // Make this a bit easier
     $name = strtolower($this->controller);
     // Add trace for debugging
     \Debug::trace("Loading routes for url...", __FILE__, __LINE__);
     // Load database
     $this->DB = $this->load->database('DB');
     // Check to see if the URI belongs to a module
     $query = "SELECT `name`, `uri2` FROM `pcms_modules` WHERE (`uri1`=? AND `uri2`='*') OR `uri1`=?";
     $result = $this->DB->query($query, array($name, $name))->fetchAll();
     // If our result is an array, Then we load it as a module
     if (is_array($result)) {
         $found = false;
         foreach ($result as $module) {
             // Handle the method, if method is an astricks, then the module will handle all requests
             if ($module['uri2'] == '*' || $module['uri2'] == $this->action) {
                 $found = true;
                 $controller = $module['name'];
                 break;
             } elseif (strpos($module['uri2'], ',') !== FALSE) {
                 // Remove any spaces, and convert to an array
                 $array = explode(',', $module['uri2']);
                 if (!in_array($this->action, $array)) {
                     // The action IS NOT in the array, Next result set
                     continue;
                 } else {
                     // The action is in the array, so we set it as that
                     $found = true;
                     $controller = $module['name'];
                     break;
                 }
             }
         }
         // If we didnt find a module for this URI, load the default controller
         if (!$found) {
             goto Skip;
         }
         // Define out globals and this controller/action
         $GLOBALS['is_module'] = TRUE;
         $this->controller = $GLOBALS['controller'] = ucfirst($controller);
         $GLOBALS['action'] = $this->action;
         // Add trace for debugging
         \Debug::trace("Found module route in database. Using {$this->controller} as controller, and {$this->action} as method", __FILE__, __LINE__);
         // Include the module controller file
         include path(ROOT, 'third_party', 'modules', $this->controller, 'controller.php');
         return TRUE;
     } else {
         Skip:
         $path = path(SYSTEM_PATH, 'controllers', $name . '.php');
         if (file_exists($path)) {
             // Define out globals and this controller/action
             $GLOBALS['is_module'] = FALSE;
             $GLOBALS['controller'] = $this->controller;
             $GLOBALS['action'] = $this->action;
             foreach (get_defined_vars() as $key => $v) {
                 $defined_vars[$key] =& ${$key};
             }
             \Debug::mark($defined_vars, __FILE__, __LINE__);
             // Add trace for debugging
             \Debug::trace("No module found for url route, using default contoller from the system/controllers folder", __FILE__, __LINE__);
             // Include the controller file
             include $path;
             return TRUE;
         } else {
             // If the method didnt exist, then we have a 404
             \Debug::trace("Controller '{$name}' doesnt exist. Displaying 404", __FILE__, __LINE__);
         }
     }
     // Neither exists, then no controller found.
     return FALSE;
 }
開發者ID:Kheros,項目名稱:Plexis,代碼行數:72,代碼來源:Plexis.php

示例8: _build_header

    protected function _build_header()
    {
        // Add trace for debugging
        \Debug::trace('Building template header', __FILE__, __LINE__);
        // Convert our JS vars into a string :)
        $string = "        var Plexis = {\n            url : '" . SITE_URL . "',\n            template_url : '{TEMPLATE_URL}',\n            debugging : false,\n            realm_id : " . get_realm_cookie() . ",\n        }\n";
        foreach ($this->jsvars as $key => $val) {
            // Format the var based on type
            $val = is_numeric($val) ? $val : '"' . $val . '"';
            $string .= "        var " . $key . " = " . $val . ";\n";
        }
        // Remove last whitespace
        $string = rtrim($string);
        // Setup the basic static headings
        $this->append_metadata("")->append_metadata("<!-- Include jQuery Scripts -->")->append_metadata('<script type="text/javascript" src="' . BASE_URL . '/assets/js/jquery.js"></script>')->append_metadata('<script type="text/javascript" src="' . BASE_URL . '/assets/js/jquery-ui.js"></script>')->append_metadata('<script type="text/javascript" src="' . BASE_URL . '/assets/js/jquery.validate.js"></script>')->append_metadata("")->append_metadata("<!-- Define Global Vars and Include Plexis Static JS Scripts -->")->append_metadata('<script type="text/javascript">
' . $string . '
    </script>')->append_metadata('<script type="text/javascript" src="' . BASE_URL . '/assets/js/plexis.js"></script>');
        // Append the template meta data
        $this->_append_template_metadata();
        // Append loaded css files
        if (!empty($this->cssfiles)) {
            $this->append_metadata("");
            // Add whitespace
            $this->append_metadata("<!-- Include Controller Defined Css Files -->");
            foreach ($this->cssfiles as $f) {
                // Find the path :O
                if (preg_match('@^(ftp|http(s)?)://@i', $f)) {
                    // We have a full url
                    $src = $f;
                } else {
                    // Just a filename
                    $src = $this->template['http_path'] . '/' . trim($this->xml->config->css_folder, '/') . '/' . $f;
                }
                // Add the stylesheet to the header
                $this->set_metadata('stylesheet', $src, 'link');
            }
        }
        // Append loaded js files
        if (!empty($this->jsfiles)) {
            $this->append_metadata("");
            // Add whitespace
            $this->append_metadata("<!-- Include Controller Defined JS Files -->");
            foreach ($this->jsfiles as $j) {
                // Find the path :O
                if (preg_match('@^(ftp|http(s)?)://@i', $j)) {
                    // We have a full url
                    $src = $j;
                } else {
                    // Just a filename
                    $path = $this->template['path'] . DS . trim($this->xml->config->js_folder, '/') . DS . $j;
                    if (file_exists(str_replace(array('/', '\\'), DS, $path))) {
                        $src = $this->template['http_path'] . '/' . trim($this->xml->config->js_folder, '/') . '/' . $j;
                    } else {
                        $src = BASE_URL . '/assets/js/' . $j;
                    }
                }
                // Add the js path
                $this->append_metadata('<script type="text/javascript" src="' . $src . '"></script>');
            }
        }
        // Add the view if we have one
        $line = $this->view_js_string();
        if ($line != false) {
            $this->append_metadata('');
            $this->append_metadata("<!-- Include the page view JS file -->");
            $this->append_metadata($line);
        }
        // Now, we build the header into a string
        $head = "";
        foreach ($this->_metadata as $data) {
            $head .= "\t" . trim($data) . "\n";
        }
        return $head;
    }
開發者ID:Kheros,項目名稱:Plexis,代碼行數:74,代碼來源:Template.php

示例9: _init_user

 protected function _init_user($userid)
 {
     // Fetch account
     $Account = $this->realm->fetchAccount($userid);
     if (!is_object($Account)) {
         // Add trace for debugging
         \Debug::trace("Account id {$userid} doesnt exist in the realm database. Failed to init user account", __FILE__, __LINE__);
         return false;
     }
     // Build our rediculas query
     $query = "SELECT \n                `activated`, \n                `pcms_accounts`.`group_id`, \n                `last_seen`, \n                `registered`, \n                `registration_ip`, \n                `language`, \n                `selected_theme`, \n                `votes`, \n                `vote_points`, \n                `vote_points_earned`, \n                `vote_points_spent`, \n                `donations`, \n                `_account_recovery`,\n                `pcms_account_groups`.`title`,\n                `pcms_account_groups`.`is_banned`,\n                `pcms_account_groups`.`is_user`,\n                `pcms_account_groups`.`is_admin`,\n                `pcms_account_groups`.`is_super_admin`,\n                `pcms_account_groups`.`permissions`\n            FROM `pcms_accounts` INNER JOIN `pcms_account_groups` ON \n            pcms_accounts.group_id = pcms_account_groups.group_id WHERE `id` = ?";
     // Query our database and get the users information
     $result = $this->DB->query($query, array($Account->getId()), false)->fetchRow();
     // If the user doesnt exists in the table, we need to insert it
     if ($result === false) {
         // Add trace for debugging
         \Debug::trace("User account '{$Account->getUsername()}' doesnt exist in Plexis database, fetching account from realm", __FILE__, __LINE__);
         $data = array('id' => $Account->getId(), 'username' => ucfirst(strtolower($Account->getUsername())), 'email' => $Account->getEmail(), 'activated' => 1, 'registered' => $Account->joinDate() == false ? date("Y-m-d H:i:s", time()) : $Account->joinDate(), 'registration_ip' => $this->data['ip_address']);
         $this->DB->insert('pcms_accounts', $data);
         $result = $this->DB->query($query)->fetchRow();
         // If the insert failed, we have a fatal error
         if ($result === false) {
             // Add trace for debugging
             \Debug::trace("There was a fatal error trying to insert account data into the plexis database", __FILE__, __LINE__);
             show_error('fatal_error', false, E_ERROR);
             return false;
         }
     }
     // Load our perms into a different var and unset
     $perms = unserialize($result['permissions']);
     unset($result['permissions']);
     // Make sure we have access to our account, we have to do this after saving the session unfortunatly
     if ((!isset($perms['account_access']) || $perms['account_access'] == 0) && $result['is_super_admin'] == 0) {
         // Add trace for debugging
         \Debug::trace("User has no permission to access account. Login failed.", __FILE__, __LINE__);
         output_message('warning', 'account_access_denied');
         return false;
     }
     // We are good, save permissions for this user
     $this->load_permissions($result['group_id'], $perms);
     // Make sure the account isnt locked due to verification
     if ($result['activated'] == false && config('reg_email_verification') == TRUE) {
         // Add trace for debugging
         \Debug::trace("Account '{$username}' is unactivated. Login failed.", __FILE__, __LINE__);
         output_message('warning', 'login_failed_account_unactivated');
         return false;
     }
     // Custom variable for QA checking
     $result['_account_recovery'] = $result['_account_recovery'] != null && strlen($result['_account_recovery']) > 10;
     // Set our users info up the the session and carry onwards :D
     $this->data = array_merge(array('logged_in' => true, 'id' => $Account->getId(), 'username' => ucfirst(strtolower($Account->getUsername())), 'email' => $Account->getEmail(), 'ip_address' => $this->data['ip_address']), $result);
     // Add trace for debugging
     \Debug::trace('Loaded user ' . $Account->getUsername(), __FILE__, __LINE__);
     return true;
 }
開發者ID:Kheros,項目名稱:Plexis,代碼行數:55,代碼來源:User.php

示例10: trigger

 public function trigger($event, $params = array())
 {
     // Get calling
     $backtrace = debug_backtrace();
     // Add trace for debugging
     \Debug::trace("Event \"{$event}\" triggered from: {$backtrace[0]['file']} on line {$backtrace[0]['line']}", __FILE__, __LINE__);
     // Free up memory
     unset($backtrace);
     // Check that event exists
     if (array_key_exists($event, self::$events)) {
         foreach (self::$events[$event] as $callback) {
             // If the callback is an array, then we call a class/method
             if (is_array($callback)) {
                 list($c, $a) = $callback;
                 // Try and proccess this manually as call_user_func_array is 2x slower then this!
                 switch (count($params)) {
                     case 0:
                         $c->{$a}();
                         break;
                     case 1:
                         $c->{$a}($params[0]);
                         break;
                     case 2:
                         $c->{$a}($params[0], $params[1]);
                         break;
                     case 3:
                         $c->{$a}($params[0], $params[1], $params[2]);
                         break;
                     case 4:
                         $c->{$a}($params[0], $params[1], $params[2], $params[3]);
                         break;
                     case 5:
                         $c->{$a}($params[0], $params[1], $params[2], $params[3], $params[4]);
                         break;
                     default:
                         call_user_func_array(array($c, $a), $params);
                         break;
                 }
             } else {
                 // Try and proccess this manually as call_user_func_array is 2x slower then this!
                 switch (count($params)) {
                     case 0:
                         $callback();
                         break;
                     case 1:
                         $callback($params[0]);
                         break;
                     case 2:
                         $callback($params[0], $params[1]);
                         break;
                     case 3:
                         $callback($params[0], $params[1], $params[2]);
                         break;
                     case 4:
                         $callback($params[0], $params[1], $params[2], $params[3]);
                         break;
                     case 5:
                         $callback($params[0], $params[1], $params[2], $params[3], $params[4]);
                         break;
                     default:
                         call_user_func_array($callback, $params);
                         break;
                 }
             }
         }
         return true;
     }
     return false;
 }
開發者ID:Kheros,項目名稱:Plexis,代碼行數:69,代碼來源:Events.php

示例11: showTrace

 /**
  * 顯示頁麵Trace信息
  * @access private
  */
 private function showTrace()
 {
     // 係統默認顯示信息
     $files = get_included_files();
     $info = array();
     foreach ($files as $key => $file) {
         $info[] = $file . ' ( ' . number_format(filesize($file) / 1024, 2) . ' KB )';
     }
     $trace = array();
     $base = array('請求信息' => date('Y-m-d H:i:s', $_SERVER['REQUEST_TIME']) . ' ' . $_SERVER['SERVER_PROTOCOL'] . ' ' . $_SERVER['REQUEST_METHOD'] . ' : ' . __SELF__, '運行時間' => $this->showTime(), '內存開銷' => MEMORY_LIMIT_ON ? number_format((memory_get_usage() - $GLOBALS['_startUseMems']) / 1024, 2) . ' kb' : '不支持', '查詢信息' => Debug::record('db_query') . ' queries ' . Debug::record('db_write') . ' writes ', '文件加載' => count(get_included_files()), '緩存信息' => Debug::record('cache_read') . ' gets ' . Debug::record('cache_write') . ' writes ', '配置加載' => count(c()), '會話信息' => 'SESSION_ID=' . session_id());
     // 讀取項目定義的Trace文件
     $traceFile = CONF_PATH . 'trace.php';
     if (is_file($traceFile)) {
         $base = array_merge($base, include $traceFile);
     }
     $debug = Debug::trace();
     $tabs = C('TRACE_PAGE_TABS');
     foreach ($tabs as $name => $title) {
         switch (strtoupper($name)) {
             case 'BASE':
                 // 基本信息
                 $trace[$title] = $base;
                 break;
             case 'FILE':
                 // 文件信息
                 $trace[$title] = $info;
                 break;
             default:
                 // 調試信息
                 $name = strtoupper($name);
                 if (strpos($name, '|')) {
                     // 多組信息
                     $array = explode('|', $name);
                     $result = array();
                     foreach ($array as $name) {
                         $result += isset($debug[$name]) ? $debug[$name] : array();
                     }
                     $trace[$title] = $result;
                 } else {
                     $trace[$title] = isset($debug[$name]) ? $debug[$name] : '';
                 }
         }
     }
     if ($save = C('PAGE_TRACE_SAVE')) {
         // 保存頁麵Trace日誌
         if (is_array($save)) {
             // 選擇選項卡保存
             $tabs = C('TRACE_PAGE_TABS');
             $array = array();
             foreach ($save as $tab) {
                 $array[] = $tabs[$tab];
             }
         }
         $content = date('[ c ]') . ' ' . Response::get_client_ip() . ' ' . $_SERVER['REQUEST_URI'] . "\r\n";
         foreach ($trace as $key => $val) {
             if (!isset($array) || in_array($key, $array)) {
                 $content .= '[ ' . $key . " ]\r\n";
                 if (is_array($val)) {
                     foreach ($val as $k => $v) {
                         $content .= (!is_numeric($k) ? $k . ':' : '') . print_r($v, true) . "\r\n";
                     }
                 } else {
                     $content .= print_r($val, true) . "\r\n";
                 }
                 $content .= "\r\n";
             }
         }
         error_log(str_replace('<br/>', "\r\n", $content), Log::FILE, LOG_PATH . date('y_m_d') . '_trace.log');
     }
     unset($files, $info, $base);
     // 調用Trace頁麵模板
     ob_start();
     include C('TMPL_TRACE_FILE');
     return ob_get_clean();
 }
開發者ID:minowu,項目名稱:smartthink,代碼行數:79,代碼來源:ShowPageTrace.php

示例12: _initWowlib

 protected function _initWowlib()
 {
     // Include the wowlib file
     require path(ROOT, 'third_party', 'wowlib', 'Wowlib.php');
     // Add Trace
     \Debug::trace('Initializing Wowlib...', __FILE__, __LINE__);
     // Try to init the wowlib
     try {
         \Wowlib::Init(config('emulator'));
         \Debug::trace('Wowlib Initialized successfully', __FILE__, __LINE__);
     } catch (Exception $e) {
         \Debug::silent_mode(false);
         \Debug::trace('Wowlib failed to initialize. Message thrown was: ' . $e->getMessage(), __FILE__, __LINE__);
         show_error('Wowlib Error: ' . $e->getMessage(), false, E_ERROR);
     }
 }
開發者ID:Kheros,項目名稱:Plexis,代碼行數:16,代碼來源:Loader.php

示例13: wsCall

 protected function wsCall($method, $params = [])
 {
     $done = false;
     while (!$done) {
         try {
             $raw_response = $this->rawWSCall($method, $params);
             break;
         } catch (RippleAPIException $e) {
             Debug::trace("error=" . $e->getRippleErrorName(), __FILE__, __LINE__, $this);
             if ($e->getRippleErrorName() == 'slowDown') {
                 $sleep = rand(50000, 1000000);
                 Debug::trace("slow down request received. sleeping for {$sleep}...", __FILE__, __LINE__, $this);
                 // slow down
                 usleep($sleep);
                 // 50ms - 1 second
             } else {
                 throw $e;
             }
         }
     }
     return $raw_response;
 }
開發者ID:deweller,項目名稱:ripple-ws-client,代碼行數:22,代碼來源:RippleAPI.php

示例14: _process_db

 private function _process_db()
 {
     // For starts, get our current database version
     $query = "SELECT `value` FROM `pcms_versions` WHERE `key`='database'";
     $version = real_ver($this->DB->query($query)->fetchColumn());
     if ($version < real_ver(REQ_DB_VERSION)) {
         $updates = array();
         $path = path(SYSTEM_PATH, "sql", "updates");
         // Add trace for debugging
         \Debug::trace("Updating core database from {$version} to " . REQ_DB_VERSION, __FILE__, __LINE__);
         // Open the __updates directory and scan all updates
         $list = @opendir($path);
         if ($list) {
             while (false !== ($file = readdir($list))) {
                 if ($file[0] != "." && !is_dir(path($path, $file))) {
                     // Format should be like so "update_#.sql
                     $names = explode('_', $file);
                     $update = str_replace('.sql', '', $names[1]);
                     if (real_ver($update) > $version) {
                         $updates[] = array('file' => $file, 'version' => $update);
                     }
                 }
             }
             @closedir($list);
         }
         // If we have updates
         if (!empty($updates)) {
             // Order them by rev
             sort($updates);
             // Process updates
             foreach ($updates as $update) {
                 if (!$this->DB->utilities->runSqlFile($path . DS . $update['file'])) {
                     // Add trace for debugging
                     \Debug::trace('Database update to version ' . $version . ' failed!', __FILE__, __LINE__);
                     log_message('Failed to run SQL file "' . $path . DS . $update['file'] . '" on database', 'error.log');
                     break;
                 }
                 // Add trace for debugging
                 \Debug::trace('Database successfully updated to version ' . $version, __FILE__, __LINE__);
                 $version = $update['version'];
             }
         }
     }
     // Define our REAL db version now, after updates are run
     define('CMS_DB_VERSION', $version);
 }
開發者ID:Kheros,項目名稱:Plexis,代碼行數:46,代碼來源:Controller.php

示例15: route_url

 public function route_url()
 {
     // Add trace for debugging
     \Debug::trace('Routing url...', __FILE__, __LINE__);
     // Determine our http hostname, and site directory
     $this->http_host = rtrim($_SERVER['HTTP_HOST'], '/');
     $this->site_dir = dirname($_SERVER['PHP_SELF']);
     // Detect our protocol
     if (isset($_SERVER['HTTPS'])) {
         if (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] != 'off') {
             $this->protocol = 'https';
         } else {
             $this->protocol = 'http';
         }
     } else {
         $this->protocol = 'http';
     }
     // Build our Full Base URL
     $site_url = $this->http_host . '/' . $this->site_dir;
     while (strpos($site_url, '//') !== FALSE) {
         $site_url = str_replace('//', '/', $site_url);
     }
     $this->site_url = str_replace('\\', '', $this->protocol . '://' . rtrim($site_url, '/'));
     // Process the site URI
     if (!$this->config->get('enable_query_strings', 'Core')) {
         // Get our current url, which is passed on by the 'url' param
         $this->uri = isset($_GET['url']) ? $this->input->get('url', TRUE) : '';
     } else {
         // Define our needed vars
         $c_param = $this->config->get('controller_param', 'Core');
         $a_param = $this->config->get('action_param', 'Core');
         // Make sure we have a controller at least
         $c = $this->input->get($c_param, TRUE);
         if (!$c) {
             $this->uri = '';
         } else {
             // Get our action
             $a = $this->input->get($a_param, TRUE);
             if (!$a) {
                 $a = $this->config->get('default_action', 'Core');
             }
             // Default Action
             // Init the uri
             $this->uri = $c . '/' . $a;
             // Clean the query string
             $qs = $this->input->clean($_SERVER['QUERY_STRING']);
             $qs = explode('&', $qs);
             foreach ($qs as $string) {
                 // Convert this segment to an array
                 $string = explode('=', $string);
                 // Dont add the controller / action twice ;)
                 if ($string[0] == $c_param || $string[0] == $a_param) {
                     continue;
                 }
                 // Append the uri vraiable
                 $this->uri .= '/' . $string[1];
             }
         }
     }
     // If the URI is empty, then load defaults
     if (empty($this->uri)) {
         // Set our Controller / Action to the defaults
         $controller = $this->config->get('default_controller', 'Core');
         // Default Controller
         $action = $this->config->get('default_action', 'Core');
         // Default Action
         $queryString = array();
         // Default query string
     } else {
         // Remove any left slashes or double slashes
         $this->uri = ltrim(str_replace('//', '/', $this->uri), '/');
         // We will start by bulding our controller, action, and querystring
         $urlArray = array();
         $urlArray = explode("/", $this->uri);
         $controller = $urlArray[0];
         // If there is an action, then lets set that in a variable
         array_shift($urlArray);
         if (isset($urlArray[0]) && !empty($urlArray[0])) {
             $action = $urlArray[0];
             array_shift($urlArray);
         } else {
             $action = $this->config->get('default_action', 'Core');
             // Default Action
         }
         // $queryString is what remains
         $queryString = $urlArray;
     }
     // Tell the system we've routed
     $this->routed = true;
     // Make sure the first character of the controller is not an _ !
     if (strncmp($controller, '_', 1) == 0 || strncmp($action, '_', 1) == 0) {
         // Add this to the trace
         \Debug::trace('Controller or action contains a private prefix "_", showing 404', __FILE__, __LINE__);
         show_404();
     }
     // Set static Variables
     $this->controller = $controller;
     $this->action = $action;
     $this->queryString = $queryString;
     // Add trace for debugging
//.........這裏部分代碼省略.........
開發者ID:Kheros,項目名稱:Plexis,代碼行數:101,代碼來源:Router.php


注:本文中的Debug::trace方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。