UCHOME2.0积分机制分析
A:管理员在后台修改积分规则
B:数据被写入数据表creditrule 中,其中rewardtype=1表示奖励措施rewardtype=0表示处罚措施并将数据写入缓存文件data/data_creditrule.php 中
C:用户发表文章或者进行其他操作的时候,通过getreward函数来获取奖罚积分  
D:然后通过SQL语句将数据写入用户数据库表space中,从而增加或减少用户积分  
E:getreward函数部分通过包含data/data_creditrule.php 缓存文件来调用积分规则
  
UCHOME积分变动提示是通过footer.htm监控的,代码如下:
  

<script type="text/javascript">
  showreward();
</script>

 

 查下source/script_common.js中showreward函数,找到AJAX处理页面为source/do_ajax.php中的getreward部分,代码如下
  
代码

elseif($op == 'getreward') {
    
$reward = '';
    
if($_SCOOKIE['reward_log']) {
        
$log = explode(',', $_SCOOKIE['reward_log']);
        
if(count($log== 2 && $log[1]) {
            @
include_once(S_ROOT.'./data/data_creditrule.php');
            
$query = $_SGLOBAL['db']->query("SELECT * FROM ".tname('creditlog')." WHERE clid='$log[1]'");
            
$creditlog = $_SGLOBAL['db']->fetch_array($query);
            
$rule = $_SGLOBAL['creditrule'][$log[0]];
            
$rule['cyclenum'= $rule['rewardnum']? $rule['rewardnum'- $creditlog['cyclenum': 0;
        }
        ssetcookie(
'reward_log', '');
    }
    
}

 

   功能都在这里了,下面就开始往表creditlog里插条数据,我这里加的是天声人语的奖励规则。SQL如下:
 

代码
INSERT INTO `前缀_creditrule` (`rid` ,`rulename` ,`action` ,`cycletype` ,`cycletime` ,`rewardnum` ,`rewardtype` ,`norepeat` ,`credit` ,`experience`)VALUES (NULL , '天声人语''publishtsry''1''0'1''1''0''10''1');

 

   你也可直接用PHPMYADMIN进行添加,值的含义参照后台其他积分的规则,更新一下缓存(重要)。
  然后在需要显示积分提示的地方加上:(注意红色地方是自定义的积分动作)
  //积分提示

代码
$reward = getreward('publishtsry', 0);
$_SGLOBAL['db']->query('UPDATE '.tname('space')." SET credit=credit+$reward[credit], experience=experience+$reward[experience] WHERE uid='{$_SGLOBAL['supe_uid']}'");

 


 

posted on 2010-06-09 22:51  小炒花生米  阅读(721)  评论(0编辑  收藏  举报