2009年10月12日 浏览 9,881 次
admin
< ?php
/*
[UCenter Home] (C) 2007-2008 Comsenz Inc.
$Id: cp_blog.php 2009-10-12 20:37:00
@author ymaozi
@copyright http://www.codedesign.cn
@uchome源码交流QQ群:83400173
*/
if(!defined('IN_UCHOME')) {
exit('Access Denied');
}
//检查信息
$blogid = empty($_GET['blogid'])?0:intval($_GET['blogid']);
$op = empty($_GET['op'])?'':$_GET['op'];
$blog = array();
if($blogid) { //如果blogid存在,则获取日志信息
$query = $_SGLOBAL['db']->query("SELECT bf.*, b.* FROM ".tname('blog')." b
LEFT JOIN ".tname('blogfield')." bf ON bf.blogid=b.blogid
WHERE b.blogid='$blogid'");
$blog = $_SGLOBAL['db']->fetch_array($query);
}
阅读全文…
2009年10月11日 浏览 7,089 次
admin
< ?php
/*
[UCenter Home] (C) 2007-2008 Comsenz Inc.
$Id: space_blog.php 2009-10-11 23:20:00
@author ymaozi
@copyright http://www.codedesign.cn
@uchome源码交流QQ群:83400173
*/
if(!defined('IN_UCHOME')) {
exit('Access Denied');
}
$minhot = $_SCONFIG['feedhotmin']<1?3:$_SCONFIG['feedhotmin'];
$page = empty($_GET['page'])?1:intval($_GET['page']);
if($page<1) $page=1;
$id = empty($_GET['id'])?0:intval($_GET['id']); //获取日志id
$classid = empty($_GET['classid'])?0:intval($_GET['classid']); //获取日志分类
//表态分类
@include_once(S_ROOT.'./data/data_click.php'); //获取表态的一些信息
$clicks = empty($_SGLOBAL['click']['blogid'])?array():$_SGLOBAL['click']['blogid']; //获取日志的表态信息
阅读全文…
2009年10月10日 浏览 1,131 次
admin
UCHome的对于统计在线用户的操作,是通过向session表中写入用户的信息,然后通过统计session表中的记录值来统计在线用户的数量与信息的.
每当前用户登录的时候,先判断用户的是否登录成功,如果登录成功,之后再检查session表,如果有过期用户的信息,则通过insertsession()函数来更新用户表的信息,如果表中存在该用户的session并且有过期的用户,则删除,插入刚登录用户,来看看他是怎么操作的吧! 阅读全文…
2009年10月7日 浏览 1,360 次
admin
< ?php
/*
[UCenter Home] (C) 2007-2008 Comsenz Inc.
$Id: index.php 2009-10-7 20:44:00
@author ymaozi
@copyright http://www.codedesign.cn
@deprecated uchome源码交流QQ群:83400173
*/
include_once('./common.php'); //引入公共文件
//is_numeric();检测变量是否为数字
if(is_numeric($_SERVER['QUERY_STRING'])) {
showmessage('enter_the_space', "space.php?uid=$_SERVER[QUERY_STRING]", 0);
}
阅读全文…
2009年10月3日 浏览 938 次
admin
< ?php
/**
* [UCenter Home] (C) 2007-2008 Comsenz Inc.
* $Id: do_lostpasswd.php 2009-10-3 03:46:00
* @author ymaozi
* @copyright http://www.codedesign.cn
* @deprecated uchome源码交流QQ群:83400173
*/
if(!defined('IN_UCHOME')) {
exit('Access Denied');
}
$op = empty($_GET['op'])?'':$_GET['op'];
if(submitcheck('lostpwsubmit')) {
$spaceinfo = array();
$query = $_SGLOBAL['db']->query('SELECT s.uid, s.groupid, s.username, s.flag, sf.email, sf.emailcheck FROM '.tname('space').' s LEFT JOIN '.tname('spacefield')." sf ON sf.uid=s.uid WHERE s.username='$_POST[username]'");
//通过用户名查找用户的uid,用户组,用户名,是否受保护,email,以及email是不是通过验证
阅读全文…
2009年10月3日 浏览 2,129 次
admin
< ?php
/**
* [UCenter Home] (C) 2007-2008 Comsenz Inc.
* $Id: do_login.php 2009-10-3 02:20:00
* @author ymaozi
* @copyright http://www.codedesign.cn
* @deprecated uchome源码交流QQ群:83400173
*/
if(!defined('IN_UCHOME')) {
exit('Access Denied');
}
include_once(S_ROOT.'./source/function_cp.php');
if($_SGLOBAL['supe_uid']) {
showmessage('do_success', 'space.php', 0);
}
$refer = empty($_GET['refer'])?rawurldecode($_SCOOKIE['_refer']):$_GET['refer'];
//如果没有获取到$refer值,则取cookie中的refer值,并对refer已编码的url通过rawurldecode()函数进行解码
preg_match("/(admincp|do|cp)\.php\?ac\=([a-z]+)/i", $refer, $ms);
/*
例:$refer:space.php?do=home
$ms[0]:space.php?do=home
$ms[1]:space;
$ms[2]:home
*/
if($ms) {
if($ms[1] != 'cp' || $ms[2] != 'sendmail') $refer = '';
}
阅读全文…
2009年10月2日 浏览 2,164 次
admin
< ?php
/**
* [UCenter Home] (C) 2007-2008 Comsenz Inc.
* @Id: do_register.php 2009-10-2 00:00:00
* @author ymaozi
* @copyright http://www.codedesign.cn
* @deprecated uchome源码交流QQ群:83400173
*/
if(!defined('IN_UCHOME')) {
exit('Access Denied');
}
$op = $_GET['op'] ? trim($_GET['op']) : '';
if($_SGLOBAL['supe_uid']) { //如果存在uid则直接进行用户空间
showmessage('do_success', 'space.php?do=home', 0);
}
//没有登录表单
$_SGLOBAL['nologinform'] = 1;
//好友邀请
$uid = empty($_GET['uid'])?0:intval($_GET['uid']);
$code = empty($_GET['code'])?'':$_GET['code'];
$app = empty($_GET['app'])?'':intval($_GET['app']); //获取应用的id
$invite = empty($_GET['invite'])?'':$_GET['invite'];
$invitearr = array();
阅读全文…
<?php
/*
[UCenter Home] (C) 2007-2008 Comsenz Inc.
$Id: common.php 13217 2009-9-25 ymaozi http://www.codedesign.cn
*/
@define('IN_UCHOME', TRUE); //定义IN_UCHOME
define('D_BUG', '0'); //定义错误等级
D_BUG?error_reporting(7):error_reporting(0);
set_magic_quotes_runtime(0); //关闭自动转义功能
$_SGLOBAL = $_SCONFIG = $_SBLOCK = $_TPL = $_SCOOKIE = $_SN = $space = array();
//程序目录
define('S_ROOT', dirname(__FILE__).DIRECTORY_SEPARATOR); //定义程序的根目录
//基本文件
include_once(S_ROOT.'./ver.php'); //导入uchome的一些版本信息
if(!@include_once(S_ROOT.'./config.php')) { //判断是否存在网站配置文件,不存在的话,安装网站
header("Location: install/index.php");//安装
exit();
}
include_once(S_ROOT.'./source/function_common.php'); //引入公共函数文件
//时间
$mtime = explode(' ', microtime()); //将当前的时间,微秒与年/月/日 时/分/秒 分隔开
$_SGLOBAL['timestamp'] = $mtime[1]; //取得当前的年/月/日 时/分/钞
$_SGLOBAL['supe_starttime'] = $_SGLOBAL['timestamp'] + $mtime[0]; //年/月/日 时/分/钞 + 微秒
//GPC过滤
$magic_quote = get_magic_quotes_gpc(); //是否开启了自动转义功能
if(empty($magic_quote)) { //如果没有开启则手动对提交的$_POST,$_GET进行转义
$_GET = saddslashes($_GET);
$_POST = saddslashes($_POST);
}
//本站URL
if(empty($_SC['siteurl'])) $_SC['siteurl'] = getsiteurl();
//链接数据库
dbconnect();
//缓存文件
if(!@include_once(S_ROOT.'./data/data_config.php')) { //是否存在网站初始化信息的缓存
include_once(S_ROOT.'./source/function_cache.php'); //如果不存在,则引入处理缓存的文件
config_cache(); //创建缓存文件
include_once(S_ROOT.'./data/data_config.php'); //将缓存文件引入
}
foreach (array('app', 'userapp', 'ad', 'magic') as $value) {
@include_once(S_ROOT.'./data/data_'.$value.'.php'); //导入app,userapp,ad,magic配置文件
}
//COOKIE
$prelength = strlen($_SC['cookiepre']); //获取COOKIE前缀长度
foreach($_COOKIE as $key => $val) {
if(substr($key, 0, $prelength) == $_SC['cookiepre']) {
$_SCOOKIE[(substr($key, $prelength))] = empty($magic_quote) ? saddslashes($val) : $val;
}
}
//启用GIP
if ($_SC['gzipcompress'] &amp;&amp; function_exists('ob_gzhandler')) {
ob_start('ob_gzhandler');
} else {
ob_start();
}
//初始化
$_SGLOBAL['supe_uid'] = 0;
$_SGLOBAL['supe_username'] = ''; //将用户的uid与username设置为空
$_SGLOBAL['inajax'] = empty($_GET['inajax'])?0:intval($_GET['inajax']); //是否采用ajax
$_SGLOBAL['mobile'] = empty($_GET['mobile'])?'':trim($_GET['mobile']); //获取$_GET提交的手机号
$_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'] = '';
//登录注册防灌水机
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']));
//整站风格
if(empty($_SCONFIG['template'])) { //如果没有设置网站的风格则采用default中的
$_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);
}
}
//url:http://u.codedesign.cn/space.php?do=home
//$_SERVER['REQUEST_URI']得到的:space.php?do=home
//$_SERVER['PHP_SELF'] 得到的:space.php
//$_SERVER['QUERY_STRING'] : do=home
//处理REQUEST_URI
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)); //将用户的uid与当前时间的前六位进行md5加密
//用户菜单
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;
}
}
}
}
?>
首先我对uc_client的引入文件开始分析:client.php 文件进行分析 通过这个文件,处理不同的关于用户的信息操作
[sourcecode language='php']
< ?php
/**
* 文件名称:client.php
* 功能:通过调用这个文件的不同函数,寻找不同的控制器与不同的方法
*
* @copyright 2009 ymaozi Site:www.codedesign.cn
* QQ群:83400173
* 分析时间:2009-6-7
*/
if(!defined('UC_API')) {
exit('Access dened');
} //是否定义UC_API,在config.php定义的是ucenter的url
error_reporting(0); //屏蔽所有的错误
define('IN_UC', TRUE); //定义IN_UC,以防直接访问控制文件
define('UC_CLIENT_VERSION', '1.5.0'); //定义版本
define('UC_CLIENT_RELEASE', '20081212'); //定义版本更新时间
define('UC_ROOT', substr(__FILE__, 0, -10)); //note 用户中心客户端的根目录 UC_CLIENTROOT
define('UC_DATADIR', UC_ROOT.'./data/'); //note 用户中心的数据缓存目录
define('UC_DATAURL', UC_API.'/data'); //note 用户中心的数据 URL
define('UC_API_FUNC', UC_CONNECT == 'mysql' ? 'uc_api_mysql' : 'uc_api_post'); //如果数据库是mysql则执行uc_api_mysql()函数,否则则执行uc_api_post
$GLOBALS['uc_controls'] = array(); //定义一全局数组
/**
* 在执行sql语句时,在需要在某些字符前加上了反斜线,这些字符有单引号(')、双引号(")、反斜线(\)
*
* @param string/array $string 如果$string 为字符串,则直接用转换,如果是数组的话,通过foreach循环遂个进行转换
* @param bool $force
* @param bool $strip
* @return string
* get_magic_quotes_gpc():本函式取得 PHP 环境设定的变数 magic_quotes_gpc (GPC, Get/Post/Cookie) 值。如果传回0为关闭,1为打开
* string addslashes(string str) 在某些字符前加上了反斜线
* string stripslashes (string str) 将用addslashes()函数处理后的字符串返回原样。
*/ 阅读全文…
2009年6月10日 浏览 5,910 次
admin
没试学学jQuery,搜索自动提示,这个功能一直感觉都挺不错,就是一直没有做,今天学习jQuery,随便也做一下这个小东西,可能不是很完美,但想展示的只是一个思路,现在开始看看代码吧! 阅读全文…