⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 control.php.svn-base

📁 PHP 知识管理系统(基于树结构的知识管理系统), 英文原版的PHP源码。
💻 SVN-BASE
字号:
<?php/* * $Id$ * * KnowledgeTree Community Edition * Document Management Made Simple * Copyright (C) 2008 KnowledgeTree Inc. * Portions copyright The Jam Warehouse Software (Pty) Limited *  * This program is free software; you can redistribute it and/or modify it under * the terms of the GNU General Public License version 3 as published by the * Free Software Foundation. *  * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more * details. *  * You should have received a copy of the GNU General Public License * along with this program.  If not, see <http://www.gnu.org/licenses/>. *  * You can contact KnowledgeTree Inc., PO Box 7775 #87847, San Francisco,  * California 94120-7775, or email info@knowledgetree.com. *  * The interactive user interfaces in modified source and object code versions * of this program must display Appropriate Legal Notices, as required under * Section 5 of the GNU General Public License version 3. *  * In accordance with Section 7(b) of the GNU General Public License version 3, * these Appropriate Legal Notices must retain the display of the "Powered by * KnowledgeTree" logo and retain the original copyright notice. If the display of the  * logo is not reasonably feasible for technical reasons, the Appropriate Legal Notices * must display the words "Powered by KnowledgeTree" and retain the original  * copyright notice. * Contributor( s): ______________________________________ * */// main library routines and defaultsrequire_once('config/dmsDefaults.php');/** * Controller page -- controls the web application by responding to a set of * defined actions.  The controller performs session handling, page-level * authentication and forwards the request to the appropriate handling * page. */// -------------------------------// page start// -------------------------------$action = $_REQUEST['action'];if ($action != 'login') {    // check the session, but don't redirect if the check fails    $ret = checkSessionAndRedirect(false);    if ($ret === true) {        //get around the problem with search        if (strcmp($_REQUEST['fForStandardSearch'], 'yes') == 0) {            $action = 'standardSearch';        } else if (!isset($action)) {        // session check succeeds, so default action should be the dashboard if no action was specified            $action = 'dashboard';        }    } else {        // session check fails, so default action should be the login form if no action was specified        $oKTConfig = KTConfig::getSingleton();        $dest = 'login';        if ($oKTConfig->get('allowAnonymousLogin', false)) { $dest = 'dashboard'; }                    if (!isset($action)) {            $action = $dest;        } elseif ($action <> $dest) {            // we have a controller link and auth has failed, so redirect to the login page            // with the controller link as the redirect            $url = generateControllerUrl('login');            $redirect = urlencode($_SERVER[PHP_SELF] . '?' . $_SERVER['QUERY_STRING']);            if ((strlen($redirect) > 1)) {                $url = $url . '&redirect=' . $redirect;            }            if (PEAR::isError($ret)) {                $url = $url . '&errorMessage=' .  urlencode($ret->getMessage());                session_start();                $_SESSION['errormessage']['login'] = $ret->getMessage();            }            redirect($url);            exit(0);        }    }}// we appear to have some encoding/decoding issues, so we need to force-check for %30 type situations$queryString = KTUtil::arrayGet($_REQUEST, 'qs', '');if (is_array($queryString)) {    $aStrings = array();    foreach ($queryString as $k => $v) {        $aStrings[] = $k . '=' . $v;    }    $queryString = join('&', $aStrings);} elseif (count(preg_match('#\%#', $queryString) != 0)) {    $queryString = urldecode($queryString);}if (empty($queryString)) {    // need to strip query string params from action before attempting to retrieve from sitemap    $queryString = '';    // check for the presence of additional params    if (strstr($_SERVER['QUERY_STRING'], '&')) {        // strip and save the querystring        $queryString = substr($_SERVER['QUERY_STRING'], strpos($_SERVER['QUERY_STRING'], '&')+1, strlen($_SERVER['QUERY_STRING']));    } else if (strstr($_SERVER['QUERY_STRING'], '?')) {        // strip and save the querystring        $queryString = substr($_SERVER['QUERY_STRING'], strpos($_SERVER['QUERY_STRING'], '?')+1, strlen($_SERVER['QUERY_STRING']));        // update        $action = substr($_SERVER['QUERY_STRING'], 0, strpos($_SERVER['QUERY_STRING'], '?'));    }}if ($action == 'dashboard') {     $oKTConfig = KTConfig::getSingleton();    if(!$oKTConfig->get('useNewDashboard')) $action = 'olddashboard'; }// retrieve the page from the sitemap (checks whether this user has access to the requested page)$page = $default->siteMap->getPage($action, isset($_SESSION['userID']) ? $_SESSION['userID'] : '');if (!$page) {    // this user doesn't have permission to access the page    // or there is no page mapping for the requested action    // redirect to no permission page    $default->log->error("control.php getPage failed for ($action, " . $_SESSION['userID'] . ")");    redirect("$default->uiUrl/noAccess.php");} else {    $page = $default->rootUrl . $page;    // set authorised flag and redirect    // strip querystring from the page returned from the sitemap    // before setting page authorisation flag (since checkSession checks page level    // access by checking $_SESSION["pageAccess"][$_SERVER["PHP_SELF"] ie. without querystring(?)        $paramStart=strpos($page, '?');    if ($paramStart !== false) {        $accessPage = substr($page, 0, $paramStart);    } else {        $accessPage = $page;    }    $_SESSION['pageAccess'][$accessPage] = true;    // if we have a querystring add it on    if (strlen($queryString) > 0) {    	$page .= ($paramStart !== false)?'&':'?';    	$page .= $queryString;        $default->log->info("control.php: about to redirect to $page");    }    redirect($page);}?>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -