zoukankan      html  css  js  c++  java
  • UCHome: 解读common.php(转)

    index.php文件第一行就是包含了include_once('./common.php');
    这里对common.php文件解析

    <?php
    /*
        [UCenter Home] (C) 2007-2008 Comsenz Inc.
        $Id: common.php 13032 2009-08-06 03:03:00Z liguode $
    */
    
    //定义一个常量,用来在其他页面中,防止被恶意用户直接调用其他PHP文件。
    @define('IN_UCHOME', TRUE);
    
    /*定义程序的调试模式,在我们调试程序的时候将常量值设为1,这样程序出错的时候会在页面显示错误信息。
      在调试完毕正常投入使用后设为0,这样程序出错不会显示给用户。
    */
    define('D_BUG', '1');
    
    //通过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);
    
    //加载基本的配置文件,用了@符号,达到找不到该文件时在页面不提示错误信息
    //ver.php中包含二个自定义的版本常量
    include_once(S_ROOT.'./ver.php');
    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());
    //$mtime[0]为UNIX时间戳(整形), $mtime[0]为毫秒
    $_SGLOBAL['timestamp'] = $mtime[1];
    $_SGLOBAL['supe_starttime'] = $_SGLOBAL['timestamp'] + $mtime[0];
    
    ////get_magic_quotes_gpc检测PHP.INI配置中的魔术引号功能是否打开
    $magic_quote = get_magic_quotes_gpc();
    if(empty($magic_quote)) {
        //如果自动过滤没打开,则对传入的参数进行转义
        $_GET = saddslashes($_GET);
        $_POST = saddslashes($_POST);
    }
    
    //本站URL,其中getsiteurl()是用来获取当前站点的域名
    if(empty($_SC['siteurl']))
        $_SC['siteurl'] = getsiteurl();
    
    //链接数据库
    dbconnect();
    
    //打开缓存文件
    if(!@include_once(S_ROOT.'./data/data_config.php')) {
         //如果缓存文件打开失败重建缓存,function_cache.php是包含建立缓存的函数文件
        include_once(S_ROOT.'./source/function_cache.php');
        config_cache();
    }
    foreach (array('app', 'userapp', 'ad', 'magic') as $value) {
        @include_once(S_ROOT.'./data/data_'.$value.'.php');
    }
    
    //获取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))] = empty($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'] = empty($_GET['inajax'])?0:intval($_GET['inajax']);//这个是用来在页面中控制一些弹出框,在模板篇会介绍
    $_SGLOBAL['mobile'] = empty($_GET['mobile'])?'':trim($_GET['mobile']);
    $_SGLOBAL['ajaxmenuid'] = empty($_GET['ajaxmenuid'])?'' _GET['ajaxmenuid'];
    $_SGLOBAL['refer'] = empty($_SERVER['HTTP_REFERER'])?'' _SERVER['HTTP_REFERER'];//获得上一页的URL,用来跳转
    if(empty($_GET['m_timestamp'])|| $_SGLOBAL['mobile'] !=md5($_GET['m_timestamp']."\t".$_SCONFIG['sitekey']))$_SGLOBAL['mobile'] = '';
    
    //登录注册防灌水机
    /*
    在登录或者注册的时候看到形如:do.php?ac=750e45d29d276b2f86f1445627c08f99的链接
    后面的750e45d29d276b2f86f1445627c08f99就是用下面的来获取的。
    */
    if(empty($_SCONFIG['login_action'])) $_SCONFIG['login_action'] = md5('login'.md5($_SCONFIG['sitekey']));
    if(empty($_SCONFIG['register_action'])) $_SCONFIG['register_action'] = md5('register'.md5($_SCONFIG['sitekey']));
    
    //整站风格,检查站点模板的路径。此处是default目录,就是我们常用黄色风格的模板路径
    if(empty($_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', '', 365000);
        }
    }
    
    //处理REQUEST_URI,查询(query)的字符串(URL 中第一个问号 ? 之后的内容)。 如为空则为当前页面
    //例:$_SERVER['REQUEST_URI']的值为/uchome/test.php
    if(!isset($_SERVER['REQUEST_URI'])) { 
        $_SERVER['REQUEST_URI'] = $_SERVER['PHP_SELF'];
    
        if(isset($_SERVER['QUERY_STRING']))
            $_SERVER['REQUEST_URI'] .= '?'.$_SERVER['QUERY_STRING'];
    }
    if($_SERVER['REQUEST_URI']) {
        $temp = urldecode($_SERVER['REQUEST_URI']);
        if(strexists($temp, '<') || strexists($temp, '"')) {
            $_GET = shtmlspecialchars($_GET);//XSS
        }
    }
       
    //判断用户登录状态
    checkauth();
    $_SGLOBAL['uhash'] = md5($_SGLOBAL['supe_uid']."\t".substr($_SGLOBAL['timestamp'], 0, 6));
    
    //用户菜单
    getuserapp();
    
    //处理UC应用,这个是漫游相关菜单,在此不用解释
    $_SCONFIG['uc_status'] = 0;
    $_SGLOBAL['appmenus'] = $_SGLOBAL['appmenu'] = array();
    if($_SGLOBAL['app']) {
        foreach ($_SGLOBAL['app'] as $appid => $value) {
            if(UC_APPID != $appid) {
                $_SCONFIG['uc_status'] = 1;
            }
            if($value['open']) {
                if(empty($_SGLOBAL['appmenu'])) {
                    $_SGLOBAL['appmenu'] = $value;
                } else {
                    $_SGLOBAL['appmenus'][] = $value;
                }
            }
        }
    }
    
    ?>
  • 相关阅读:
    最新闲鱼数据采集软件【2020年4月更新】
    拼多多改价精灵
    idhttp采集时遇到乱码问题解决
    拼多多店铺采集如何采集?【爬虫技术】
    【原创最新2018】淘宝如何获取别人店铺宝贝的上下架时间?
    android.support.v4.app.NotificationCompat引用包
    Delphi 7启动后提示Unable to rename delphi32.dro的解决办法
    NOIP 膜你题 DAY2
    NIOP 膜你题
    一个hin秀的小学三年级奥数题 [hin秀]
  • 原文地址:https://www.cnblogs.com/eastson/p/2837890.html
Copyright © 2011-2022 走看看