UCHOME的代碼還是很不錯的,學習一下!
復制代碼 代碼如下:
<?php
/**
* 定義一些常量
*/
@define('IN_UCHOME', TRUE); //據說可以防止文件非法包含
define('X_VER', '1.2'); //Uchome版本
define('X_RELEASE', '20080612');//發布日期
define('D_BUG', '0'); //是否開啟調試功能, 0:關閉, 1:開啟
//根據是否開啟調試功能設置錯誤報告級別
D_BUG?error_reporting(7):error_reporting(0);
//初始化一些全局變量
$_SGLOBAL = $_SCONFIG = $_SBLOCK = $_TPL = $_SCOOKIE = $space = array();
//定義程序目錄常量
define('S_ROOT', dirname(__FILE__).DIRECTORY_SEPARATOR);
//獲取時間,主要用於輸出程序運行時間
$mtime = explode(' ', microtime());
$_SGLOBAL['timestamp'] = $mtime[1];
$_SGLOBAL['supe_starttime'] = $_SGLOBAL['timestamp'] + $mtime[0];
//基本文件,嘗試包含基本配置文件,如果包含不成功,則安裝程序
if(!@include_once(S_ROOT.'./config.php')) {
header("Location: install/index.php");
exit();
}
//包含公用函數庫
include_once(S_ROOT.'./source/function_common.php');
//鏈接數據庫
dbconnect();
//配置文件,嘗試包含緩存目錄中的網站配置信息,如果不成功,則包含進緩存處理函數庫並生成配置緩存
if(!@include_once(S_ROOT.'./data/data_config.php')) {
include_once(S_ROOT.'./source/function_cache.php');
config_cache();
}
//強制使用字符集
if($_SCONFIG['headercharset']) {
@header('Content-Type: text/html; charset='.$_SC['charset']);
}
//GPC過濾,自動轉義$_GET,$_POST,$_COOKIE中的特殊字符,防止SQL注入攻擊
$magic_quote = get_magic_quotes_gpc();
if(emptyempty($magic_quote)) {
$_GET = saddslashes($_GET);
$_POST = saddslashes($_POST);
}
//COOKIE
$prelength = strlen($_SC['cookiepre']);
foreach($_COOKIE as $key => $val) {
if(substr($key, 0, $prelength) == $_SC['cookiepre']) {
$_SCOOKIE[(substr($key, $prelength))] = emptyempty($magic_quote) ? saddslashes($val) : $val;
}
}
//啟用GIP
if ($_SC['gzipcompress'] && function_exists('ob_gzhandler')) {
ob_start('ob_gzhandler');
} else {
ob_start();
}
//初始化
$_SGLOBAL['supe_uid'] = 0;
$_SGLOBAL['supe_username'] = '';
$_SGLOBAL['inajax'] = emptyempty($_GET['inajax'])?0:intval($_GET['inajax']);
$_SGLOBAL['ajaxmenuid'] = emptyempty($_GET['ajaxmenuid'])?'':$_GET['ajaxmenuid'];
$_SGLOBAL['refer'] = emptyempty($_SERVER['HTTP_REFERER'])?'':$_SERVER['HTTP_REFERER'];
//獲取用戶信息
getuser();
//應用列表
@include_once(S_ROOT.'./data/data_app.php');
if(emptyempty($_SGLOBAL['app'])) {
include_once(S_ROOT.'./source/function_cache.php');
app_cache();
}
?>
<?php
/**
* 定義一些常量
*/
@define('IN_UCHOME', TRUE); //據說可以防止文件非法包含
define('X_VER', '1.2'); //Uchome版本
define('X_RELEASE', '20080612');//發布日期
define('D_BUG', '0'); //是否開啟調試功能, 0:關閉, 1:開啟
//根據是否開啟調試功能設置錯誤報告級別
D_BUG?error_reporting(7):error_reporting(0);
//初始化一些全局變量
$_SGLOBAL = $_SCONFIG = $_SBLOCK = $_TPL = $_SCOOKIE = $space = array();
//定義程序目錄常量
define('S_ROOT', dirname(__FILE__).DIRECTORY_SEPARATOR);
//獲取時間,主要用於輸出程序運行時間
$mtime = explode(' ', microtime());
$_SGLOBAL['timestamp'] = $mtime[1];
$_SGLOBAL['supe_starttime'] = $_SGLOBAL['timestamp'] + $mtime[0];
//基本文件,嘗試包含基本配置文件,如果包含不成功,則安裝程序
if(!@include_once(S_ROOT.'./config.php')) {
header("Location: install/index.php");
exit();
}
//包含公用函數庫
include_once(S_ROOT.'./source/function_common.php');
//鏈接數據庫
dbconnect();
//配置文件,嘗試包含緩存目錄中的網站配置信息,如果不成功,則包含進緩存處理函數庫並生成配置緩存
if(!@include_once(S_ROOT.'./data/data_config.php')) {
include_once(S_ROOT.'./source/function_cache.php');
config_cache();
}
//強制使用字符集
if($_SCONFIG['headercharset']) {
@header('Content-Type: text/html; charset='.$_SC['charset']);
}
//GPC過濾,自動轉義$_GET,$_POST,$_COOKIE中的特殊字符,防止SQL注入攻擊
$magic_quote = get_magic_quotes_gpc();
if(emptyempty($magic_quote)) {
$_GET = saddslashes($_GET);
$_POST = saddslashes($_POST);
}
//COOKIE
$prelength = strlen($_SC['cookiepre']);
foreach($_COOKIE as $key => $val) {
if(substr($key, 0, $prelength) == $_SC['cookiepre']) {
$_SCOOKIE[(substr($key, $prelength))] = emptyempty($magic_quote) ? saddslashes($val) : $val;
}
}
//啟用GIP
if ($_SC['gzipcompress'] && function_exists('ob_gzhandler')) {
ob_start('ob_gzhandler');
} else {
ob_start();
}
//初始化
$_SGLOBAL['supe_uid'] = 0;
$_SGLOBAL['supe_username'] = '';
$_SGLOBAL['inajax'] = emptyempty($_GET['inajax'])?0:intval($_GET['inajax']);
$_SGLOBAL['ajaxmenuid'] = emptyempty($_GET['ajaxmenuid'])?'':$_GET['ajaxmenuid'];
$_SGLOBAL['refer'] = emptyempty($_SERVER['HTTP_REFERER'])?'':$_SERVER['HTTP_REFERER'];
//獲取用戶信息
getuser();
//應用列表
@include_once(S_ROOT.'./data/data_app.php');
if(emptyempty($_SGLOBAL['app'])) {
include_once(S_ROOT.'./source/function_cache.php');
app_cache();
}
?>
下面是1.5版本的common.php
復制代碼 代碼如下:
<?php
/*
[UCenter Home] (C) 2007-2008 Comsenz Inc.
$Id: common.php 10981 2009-01-14 03:05:20Z liguode $
*/
//定義一個常量,用來在其他頁面中,防止被惡意用戶直接調用其他PHP文件。
@define('IN_UCHOME', TRUE);
//定義一個常量,這個常量表示版本號
define('X_VER', '1.5');
//這個也是一個常量,次版本號
define('X_RELEASE', '20090114');
/*定義程序的調試模式,在我們調試程序的時候將常量值設為1,這樣程序出錯的時候會在頁面顯示錯誤信息。
在調試完畢正常投入使用後設為0,這樣程序出錯不會顯示給用戶。
*/
define('D_BUG', '0');
//通過D_BUG常量值指定錯誤報告類型。其中error_reporting()的參數是錯誤報告類型,相關參數可查詢PHP手冊
D_BUG?error_reporting(7):error_reporting(0);
//這下面都是定義的全局變量。具體的會在後面使用的時候一一介紹
$_SGLOBAL = $_SCONFIG = $_SBLOCK = $_TPL = $_SCOOKIE = $_SN = $space = array();
//定義程序目錄常量。其中DIRECTORY_SEPARATOR是路徑分隔符,linux上就是'/' windows上是'\'
define('S_ROOT', dirname(__FILE__).DIRECTORY_SEPARATOR);
//加載基本的配置文件,用了@符號,達到找不到該文件時在頁面不提示錯誤信息
if(!@include_once(S_ROOT.'./config.php')) {
//如果找不到的話則重定向到安裝文件
header("Location: install/index.php");
exit();
}
//通用函數文件,具體函數在介紹時間會一一解釋
include_once(S_ROOT.'./source/function_common.php');
//時間microtime()獲取含毫秒的時間
$mtime = explode(' ', microtime());
$_SGLOBAL['timestamp'] = $mtime[1];
//$mtime[0]為UNIX時間戳(整形), $mtime[0]為毫秒
$_SGLOBAL['supe_starttime'] = $_SGLOBAL['timestamp'] + $mtime[0];
//get_magic_quotes_gpc檢測PHP.INI配置中的魔術引號功能是否打開
$magic_quote = get_magic_quotes_gpc();
if(emptyempty($magic_quote)) {
//如果自動過濾每打開,則對傳入的參數進行轉義
$_GET = saddslashes($_GET);
$_POST = saddslashes($_POST);
}
//貨主站點的URL,其中getsiteurl()是用來獲取當前站點的域名
if(emptyempty($_SC['siteurl'])) $_SC['siteurl'] = getsiteurl();
//鏈接數據庫
dbconnect();
//打開緩存文件
foreach (array('config', 'app', 'userapp', 'ad') as $value) {
if(!@include_once(S_ROOT.'./data/data_'.$value.'.php')) {
//如果緩存文件打開失敗重建緩存,function_cache.php是包含建立緩存的函數文件
include_once(S_ROOT.'./source/function_cache.php');
$cache_func = $value.'_cache';
//調用相應的函數來生成緩存。
$cache_func();
}
}
//獲取COOKIE前綴的長度,$_SC['cookiepre']是在config.php中定義的COOKIE函數的前綴名稱,$_COOKIE是存放COOKIE的數據全局變量數組
$prelength = strlen($_SC['cookiepre']);
foreach($_COOKIE as $key => $val) {
//判斷當前域名下的COOKIE中屬於UCHome的COOKIE
if(substr($key, 0, $prelength) == $_SC['cookiepre']) {
//對COOKIE值進行轉義
$_SCOOKIE[(substr($key, $prelength))] = emptyempty($magic_quote) ? saddslashes($val) : $val;
}
}
//是否啟用GIP壓縮傳輸,這個是用來提高PHP傳輸速度的。
if ($_SC['gzipcompress'] && function_exists('ob_gzhandler')) {
ob_start('ob_gzhandler');
} else {
ob_start();
}
//初始化
$_SGLOBAL['supe_uid'] = 0; //初始化當前用戶的UID
$_SGLOBAL['supe_username'] = ''; //初始化當前用戶的用戶名
$_SGLOBAL['inajax'] = emptyempty($_GET['inajax'])?0:intval($_GET['inajax']); //這個是用來在頁面中控制一些彈出框,在模板篇會介紹
$_SGLOBAL['ajaxmenuid'] = emptyempty($_GET['ajaxmenuid'])?'':$_GET['ajaxmenuid'];
$_SGLOBAL['refer'] = emptyempty($_SERVER['HTTP_REFERER'])?'':$_SERVER['HTTP_REFERER']; //獲得上一頁的URL,用來跳轉
//登錄注冊防灌水機
/*
在登錄或者注冊的時候看到形如:do.php?ac=750e45d29d276b2f86f1445627c08f99的鏈接
後面的750e45d29d276b2f86f1445627c08f99就是用下面的來獲取的。
*/
if(emptyempty($_SCONFIG['login_action'])) $_SCONFIG['login_action'] = md5('login'.md5($_SCONFIG['sitekey']));
if(emptyempty($_SCONFIG['register_action'])) $_SCONFIG['register_action'] = md5('register'.md5($_SCONFIG['sitekey']));
//整站風格,檢查站點模板的路徑。此處是default目錄,就是我們常用黃色風格的模板路徑
if(emptyempty($_SCONFIG['template'])) {
$_SCONFIG['template'] = 'default';
}
//在首頁由下角可以自行選擇風格的實現就是通過這段。
if($_SCOOKIE['mytemplate']) {
$_SCOOKIE['mytemplate'] = str_replace('.','',trim($_SCOOKIE['mytemplate']));
if(file_exists(S_ROOT.'./template/'.$_SCOOKIE['mytemplate'].'/style.css')) {
$_SCONFIG['template'] = $_SCOOKIE['mytemplate'];
} else {
ssetcookie('mytemplate', '');
}
}
//處理REQUEST_URI,查詢(query)的字符串(URL 中第一個問號 ? 之後的內容)。 如為空則為當前頁面。
if(!isset($_SERVER['REQUEST_URI'])) {
$_SERVER['REQUEST_URI'] = $_SERVER['PHP_SELF'];
if(isset($_SERVER['QUERY_STRING'])) $_SERVER['REQUEST_URI'] .= '?'.$_SERVER['QUERY_STRING'];
}
//判斷用戶登錄狀態
checkauth();
//用戶菜單
getuserapp();
//處理UC應用,這個是漫游相關菜單,在此不用解釋
$_SGLOBAL['appmenus'] = $_SGLOBAL['appmenu'] = array();
if($_SGLOBAL['app']) {
foreach ($_SGLOBAL['app'] as $value) {
if($value['open']) {
if(emptyempty($_SGLOBAL['appmenu'])) {
$_SGLOBAL['appmenu'] = $value;
} else {
$_SGLOBAL['appmenus'][] = $value;
}
}
}
}
?>