Uchome1.2 1.5 代码学习 common.php


Posted in PHP onApril 24, 2009

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; 
} 
} 
} 
} 
?>
PHP 相关文章推荐
PHP+.htaccess实现全站静态HTML文件GZIP压缩传输(一)
Feb 15 PHP
PHP 获取目录下的图片并随机显示的代码
Dec 28 PHP
无法在发生错误时创建会话,请检查 PHP 或网站服务器日志,并正确配置 PHP 安装最快的解决办法
Aug 01 PHP
浅析php变量作用域的一些问题
Aug 08 PHP
浅析php数据类型转换
Jan 09 PHP
基于php实现随机合并数组并排序(原排序)
Nov 26 PHP
php使用get_class_methods()函数获取分类的方法
Jul 20 PHP
php微信开发接入
Aug 27 PHP
PHP基于关联数组20行代码搞定约瑟夫问题示例
Nov 07 PHP
YII框架实现自定义第三方扩展操作示例
Apr 26 PHP
Laravel Eloquent分表方法并使用模型关联的实现
Nov 25 PHP
php7连接MySQL实现简易查询程序的方法
Oct 13 PHP
mysql_fetch_row,mysql_fetch_array,mysql_fetch_assoc的区别
Apr 24 #PHP
PHP 危险函数解释 分析
Apr 22 #PHP
php反弹shell实现代码
Apr 22 #PHP
将数组写入txt文件 var_export
Apr 21 #PHP
php 保留小数点
Apr 21 #PHP
PHP 中执行排序与 MySQL 中排序
Apr 21 #PHP
一个php导出oracle库的php代码
Apr 20 #PHP
You might like
php下通过POST还是GET来传值
2008/06/05 PHP
PHP函数microtime()用法与说明
2013/12/04 PHP
php基于mcrypt_encrypt和mcrypt_decrypt实现字符串加密解密的方法
2016/07/12 PHP
PHP实现微信模拟登陆并给用户发送消息的方法【文字,图片,图文】
2017/06/29 PHP
php关联数组与索引数组及其显示方法
2018/03/12 PHP
PHP pthreads v3下worker和pool的使用方法示例
2020/02/21 PHP
dojo 之基础篇(三)之向服务器发送数据
2007/03/24 Javascript
jQuery多个input求和的实现方法
2015/02/12 Javascript
JavaScript Date对象详解
2016/03/01 Javascript
JavaScript数据结构之数组的表示方法示例
2017/04/12 Javascript
Vuex简单入门
2017/04/19 Javascript
VueJS 集成 Medium Editor的示例代码 (自定义编辑器按钮)
2017/08/24 Javascript
JS/CSS实现字符串单词首字母大写功能
2019/09/03 Javascript
Vue实现点击导航栏当前标签后变色功能
2020/08/19 Javascript
夯基础之手撕javascript继承详解
2020/11/09 Javascript
JS实现可以用键盘方向键控制的动画
2020/12/11 Javascript
[50:29]2014 DOTA2华西杯精英邀请赛 5 24 DK VS iG
2014/05/26 DOTA
[07:52]2014DOTA2 TI逗比武士游V社解说背后的故事
2014/07/10 DOTA
Python入门篇之面向对象
2014/10/20 Python
Python调用Windows API函数编写录音机和音乐播放器功能
2020/01/05 Python
浅析HTML5的WebSocket与服务器推送事件
2016/02/19 HTML / CSS
亚洲航空公司官方网站:AirAsia
2019/11/25 全球购物
Linux如何修改文件和文件夹的权限
2012/06/27 面试题
最新大学生自我评价
2013/09/24 职场文书
中餐厅主管的职责范文
2014/02/04 职场文书
亲戚结婚的请假条
2014/02/11 职场文书
《灰椋鸟》教学反思
2014/04/27 职场文书
3的组成教学反思
2014/04/30 职场文书
设计专业自荐信
2014/06/19 职场文书
经济类毕业生求职信
2014/06/26 职场文书
体育系毕业生自荐信
2014/06/28 职场文书
2014年店长工作总结
2014/11/17 职场文书
《牧场之国》教学反思
2016/02/22 职场文书
送给自己的励志语句:要安静的优秀,悄无声息的坚强
2019/11/26 职场文书
Python利器openpyxl之操作excel表格
2021/04/17 Python
Java spring单点登录系统
2021/09/04 Java/Android