基本信息
源码名称:thinkphp 微信抽奖源码PHP前后台+转盘+数据库完整示例
源码大小:1.71M
文件格式:.rar
开发语言:PHP
更新时间:2016-09-22
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 10 元×
微信扫码支付:10 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
1微信抽奖源码PHP前后台 转盘 数据库完整示例
1微信抽奖源码PHP前后台 转盘 数据库完整示例
1微信抽奖源码PHP前后台 转盘 数据库完整示例
<?php // 本类由系统自动生成,仅供测试用途 class IndexAction extends Action { public function index(){ if(!$this->checkCanDo()){ $this->error('您还没有抽奖权限,请登录',__URL__.'/login'); }else{ $this->display(); } } private function checkCanDo(){ $username=session(PHPOK_SESSIONNAME.'_USERNAME'); $password=session(PHPOK_SESSIONNAME.'_PASSWORD'); if($username=='' or $password==''){ $this->error('您还没有抽奖权限,请登录',__URL__.'/login'); }else{ $m=M('User'); $data=array('username'=>$username,'password'=>$password,_logic=>'and'); $row=$m->where($data)->select(); if($row){ return true; }else{ return false; } } } public function login(){ $this->display(); } public function checkLogin(){ $username=trim($_POST['username']); $password=md5($_POST['password']); if(!isset($username) || empty($username) || !isset($password) || empty($password)){ $this->error('用户名密码不能为空!',__URL__.'/login'); }else{ $m=new Model('User'); if($m->autoCheckToken($_POST)){ $resoult=$m->where(array('username'=>$username,'password'=>$password,_logic=>'and'))->select(); if($resoult){ session(PHPOK_SESSIONNAME.'_USERNAME',$username); session(PHPOK_SESSIONNAME.'_PASSWORD',$password); $this->success('登录成功,正在跳转到抽奖页面',__URL__.'/index'); }else{ $this->error('对不起,帐号或者密码不正确!',__URL__.'/login'); } } } } public function run(){ if(!$this->checkCanDo()){ $this->error('您还没有抽奖权限,请登录',__URL__.'/login'); }else{ $prize_arr=array(); $m=new Model('Config'); $arr=$m->select(); foreach($arr as $key=>$val){ $min=explode(",",$val['min']); $max=explode(",",$val['max']); if(count($min)>1){ $val['min']=$min; } if(count($max)>1){ $val['max']=$max; } $prize_arr[$key]=$val; } echo $this->getResult($prize_arr); } } private function getResult($priearr){ $arr=array(); $count=array(); foreach ($priearr as $key => $val) { $arr[$val['id']] = $val['chance']; $count[$val['id']] = $val['praisenumber']; } $rid = $this->getRand($arr,$count); //根据概率获取奖项id $res = $priearr[$rid-1]; //中奖项 $username=session(PHPOK_SESSIONNAME."_USERNAME"); $password=session(PHPOK_SESSIONNAME."_PASSWORD"); $m=M('User as u'); $row=$m->field('u.id,n.number')->join('inner join magic_useraddnumber as n on u.id=n.aid')->where(array('u.username'=>$username,'u.password'=>$password))->find(); if($row){ if($row['number']==0){ $num=0; $result['praisename'] =null; $result['angle']=0; }else{ $num=$row['number']-1; $min = $res['min']; $max = $res['max']; if(is_array($min)){ //多等奖的时候 $i = mt_rand(0,count($min)-1); $result['angle'] = mt_rand($min[$i],$max[$i]); }else{ $result['angle'] = mt_rand($min,$max); //随机生成一个角度 } $result['praisename'] = $res['praisename']; } //用户抽奖次数减1 $cjModel=M('Useraddnumber'); $cjModel->where(array('aid'=>$row['id']))->save(array('number'=>$num)); $result['num']=$num; //用户抽取的那个奖项减1 $mode=M('Config'); $row=$mode->field(praisenumber)->where(array('id'=>$res['id']))->find(); if($row['praisenumber']==-1){ $num=-1; }else if($row['praisenumber']==0){ $num=0; }else{ $num=$row['praisenumber']-1; } $mode->where(array('id'=>$res['id']))->save(array('praisenumber'=>$num)); return $this->json($result); } } private function getRand($proArr,$proCount){ $result = ''; $proSum=0; //概率数组的总概率精度 获取库存不为0的 foreach($proCount as $key=>$val){ if($val==0){ continue; }else{ $proSum=$proSum $proArr[$key]; } } //概率数组循环 � foreach ($proArr as $key => $proCur) { if($proCount[$key]==0){ continue; }else{ $randNum = mt_rand(1, $proSum);//关键 if ($randNum <= $proCur) { $result = $key; break; }else{ $proSum -= $proCur; } } } unset ($proArr); return $result; } private function json($array){ $this->arrayRecursive($array, 'urlencode', true); $json = json_encode($array); return urldecode($json); } //对数组中所有元素做处理 private function arrayRecursive(&$array, $function, $apply_to_keys_also = false){ foreach ($array as $key => $value) { if (is_array($value)) { arrayRecursive($array[$key], $function, $apply_to_keys_also); }else{ $array[$key] = $function($value); } if ($apply_to_keys_also && is_string($key)){ $new_key = $function($key); if ($new_key != $key){ $array[$new_key] = $array[$key]; unset($array[$key]); } } } } }