日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

PHP實現抽獎功能實例代碼

瀏覽:190日期:2022-09-09 17:35:31

在項目開發中經常會遇到花錢抽獎類型的需求。但是老板總是擔心用戶用小錢抽到大獎。這樣會導致項目虧損。下邊這段代碼可以有效制止抽獎項目虧錢。

個人獎池:

語言:thinkphp redis mysql

表:desire抽獎商品表 desire_log用戶抽獎獎品表 user_desire_log用戶抽獎記錄表 desire_risk抽獎風控表

需求:用戶獎池分為進行中獎池 和已完成獎池 當用戶抽到大獎后 用戶個人獎池重置 否則將繼續抽獎 最后一次抽獎必中大獎 通過風控金額來判斷用戶是否可以抽大獎

當所有用戶已完成的抽獎 盈利大于風控金額的時候可以讓用戶抽大獎 否則用戶抽不到大獎

<?php  //抽獎接口 public function desire() { $userData = $this->userSessionData();///用戶的唯一標識 $time = time(); $this->limit_reward_time($userData[’id’], $time);///限制抽獎間隔時間 防止被惡意刷獎品 //活動開啟開關 $num = input(’num/d’); if (!$num) { output(’1008’, ’參數錯誤’); } if ($num!=1){ if ($num !=10){ if ($num !=100){ output(’1008’, ’參數錯誤’); }else{ $send = $this->draw($num); } }else{ $send = $this->draw($num); } }else{ $send = $this->draw($num); } if ($send != ’金幣不足’) { output(’200’, ’列表’, $send); } else { output(’1012’, $send); } }/////抽獎核心 public function draw($num) { $userData = $this->userSessionData(); $resultSend = Cache::get(’獎池名稱加上用戶的唯一標識,確保一人一獎池’ . $userData[’id’]);//獲取個人獎池 if (!empty($resultSend)) { $userRedis = unserialize(Cache::get(’newdesiredraw’ . $userData[’id’]));///將獎池序列化 } else { $userRedis = ’’;///當前用戶不存在獎池 } ///查詢當前用戶的金幣 $desireDiamonds = Db::connect(’db_qmconfig’)->name(’user_money’)->where([’uid’ => $userData[’id’]])->field(’diamonds’)->find(); $sendNum = $num; if ($desireDiamonds[’diamonds’] < $num) { return [’msg’ => ’金幣不足’];///判斷當前用戶的金幣是不是夠抽獎 } $gift_height = 0;///檢測是否更新個人獎池和抽獎數量 $newNum = 0;///檢測下一輪抽獎數量 $suiji = Db::connect(’db_qmconfig’)->name(’desire’)->order(’num desc’)->find();///隨機小禮物 if ($userRedis) {///如果用戶獎池存在 $joins = [ [’gift_info f’, ’d.giftid = f.id’] ]; $gift = Db::connect(’db_qmconfig’)->name(’desire’) ->alias(’d’) ->join($joins) ->where([’d.state’ => 1]) ->order(’f.price desc’) ->field(’f.name,f.price,f.egif,d.num,f.id,d.position’)->find();///查詢抽獎表的禮物 if (!$gift){ return [’msg’=>’禮物查詢錯誤’]; } ///查詢用戶的總抽獎數量 $user_all = Db::connect(’db_qmconfig’)->name(’user_desire_log’)->order(’kind desc’) ->where([’uid’=>$userData[’id’],’state’=>0])->field(’SUM(num) as kindNum’)->find(); //十次抽獎 必中 $count = count($userRedis); if ($num == 10) { $where[] = [’d.state’, ’=’, 1]; $where[] = [’d.ten’, ’=’, 1]; $giftId = $this->giftInfo($where); if ($giftId) { $result[] = $giftId[0][’id’]; } $num = $num - 1; } ///百次抽獎 必中 if ($num == 100) { $where[] = [’d.state’, ’=’, 1]; $where[] = [’d.hundred’, ’=’, 1]; $giftId = $this->giftInfo($where); $lwhere[] = [’d.state’, ’=’, 1]; $lwhere[] = [’d.ten’, ’=’, 1]; $lgiftId = $this->giftInfo($lwhere); if ($lgiftId) { for ($l=0;$l<10;$l++){ $result[] = $lgiftId[0][’id’]; } } if ($giftId) { $result[] = $giftId[0][’id’]; } $num = $num - 11; } if ($num ==1){ if ($user_all){ $number1 = ’’; $num1 = str_split($user_all[’kindNum’]); $number = $num1[count($num1) - 1]; if ($user_all[’kindNum’]>98){ $number1 = $num1[count($num1) - 2]; } if (($number==9)&& ($number1 !=9)){ //十抽必中 $where[] = [’d.state’, ’=’, 1]; $where[] = [’d.ten’, ’=’, 1]; $giftId = $this->giftInfo($where); if ($giftId) { $result[] = $giftId[0][’id’]; } $num = $num - 1; } if (($number1==9) && ($number==9)){//百抽必中 $where[] = [’d.state’, ’=’, 1]; $where[] = [’d.hundred’, ’=’, 1]; $giftId = $this->giftInfo($where); if ($giftId) { $result[] = $giftId[0][’id’]; } $num = $num - 1; } } }  ////判斷當前獎池的獎品是否夠此次抽獎 如果獎池獎品數量不夠此次抽獎 將此次獎池抽完后 獲取剩下要抽將的數量 重置獎池 并且遞歸此方法傳入剩下要抽的數量 if ($count < $num) { $newNum = $num - $count; $num = $count; } $user = Db::connect(’db_qmconfig’) ->name(’desire_log’)->where([’uid’ => $userData[’id’]]) ->field(’SUM(num) as num’) ->find();///已抽數量 if (!$user){ return [’msg’=>’已抽數量有誤’]; } $res[’zongshu’] = Db::connect(’db_qmconfig’) ->name(’desire’)->where([’state’ => 1]) ->field(’SUM(num) as num,checksum’) ->find();///總數量 if (!$res[’zongshu’]){ return [’msg’=>’總數量有誤’]; } $resNum = 0; ////獲取個人多少次抽獎 if (($user[’num’]+$sendNum) > $res[’zongshu’][’checksum’]) { $res[’zongshu’][’user_num’] = $user[’num’] % $res[’zongshu’][’checksum’]; ///獲取余數 if (($res[’zongshu’][’user_num’] + $sendNum) > $res[’zongshu’][’checksum’]) { ///獲取這次抽獎的數量 $resNum = $sendNum - (($res[’zongshu’][’user_num’] + $sendNum) - $res[’zongshu’][’checksum’]); }// return [’msg’=>$res[’zongshu’][’user_num’]]; }else{ $res[’zongshu’][’user_num’] = $user[’num’]; } $cruuy = 0; ///隨機選擇獎池 for ($i = 0; $i < $num; $i++) { $send = array_rand($userRedis); if ($resNum > 0) { ///如果本輪獎池抽完 并且沒有抽到大獎 那么必中大獎 $result[] = $gift[’id’]; $gift_height = 1;//抽到大獎后更改三個變量狀態 $resNum=0; $cruuy = 1; } else { if ($userRedis[$send]==$gift[’id’]){ $haveJoin = [ [’desire_log d’, ’d.cid = u.id’], [’gift_info f’, ’d.giftid = f.id’] ]; $all = Db::connect(’db_qmconfig’) ->name(’user_desire_log’) ->alias(’u’) ->where([’u.state’=>1]) ->field(’SUM(u.num) as num’)->find();// var_dump($all);///如果抽到大獎 if ($all[’num’]==null){ ///如果這是整個獎池第一輪抽獎 那么可以中大獎 $result[] = $suiji[’giftid’]; }else{  $alls = Db::connect(’db_qmconfig’)->name(’user_desire_log’)->alias(’u’)->where([’u.state’=>1])->join($haveJoin)->field(’SUM(f.price*d.num) as num’)->find(); ///查詢獎池風控金額 $reskList = Db::connect(’db_qmconfig’)->name(’desire_risk’)->find(); $riskPrice = $all[’num’] * 20 - $alls[’num’]; ///如果風控金額小于當前已完成抽獎的金額 那么代表軟件處于盈利狀態 可以中大獎 if (($riskPrice >= $reskList[’price’])&&($cruuy==0)){$result[] = $userRedis[$send];$gift_height = 1;$cruuy = 1; } else{ ///如果風控金額大于當前已完成抽獎金額 不能中大獎 隨機選擇一次小獎品 替換大獎$result[] = $suiji[’giftid’]; } } }else{ $result[] = $userRedis[$send]; } }///清空個人獎池此次抽獎的禮物 unset($userRedis[$send]); } ////新增用戶抽獎次數 $result = array_count_values($result); $user_desire_list = Db::connect(’db_qmconfig’)->name(’user_desire_log’)->order(’id desc’)->where([’uid’=>$userData[’id’]])->find(); if ($user_desire_list){ if ($user_desire_list[’state’]==0){ $user_desire_logData[ ’kind’] = $user_desire_list[’kind’]+1; }else{ $user_desire_logData[ ’kind’] = 1; } }else{ $user_desire_logData[ ’kind’] = 1; } $user_desire_logData[’uid’] =$userData[’id’]; $user_desire_logData[’ctime’] =time(); $user_desire_logData[’num’] =$sendNum; ////更改此輪抽獎后 用戶獎池的狀態 if ($gift_height==1){ $user_desire_log_update = Db::connect(’db_qmconfig’)->name(’user_desire_log’) ->where([’uid’=>$userData[’id’],’state’=>0])->update([’state’=>1]); $user_desire_logData[ ’state’] = 1; }else{ $user_desire_logData[ ’state’] = 0; } $user_desire_log = Db::connect(’db_qmconfig’)->name(’user_desire_log’)->insertGetId($user_desire_logData); foreach ($result as $k => $v) { if ($resNum == ($k + 1)) { ///如果這次抽獎大于獎池總數 那么更新獎池并且抽獎剩下的次數 Cache::set(’newdesiredraw’ . $userData[’id’], serialize([])); return $this->draw($sendNum - ($k + 1)); } ////禮物新增用戶背包 $data = [ ’uid’ => $userData[’id’], ’giftid’ => $k, ’num’ => $v, ’ctime’ => time(), ’cid’ => $user_desire_log ]; $join = [ [’gift_info f’, ’d.giftid = f.id’] ]; $gift_info = Db::connect(’db_qmconfig’)->name(’desire’) ->alias(’d’) ->join($join) ->where([’d.giftid’ => $k]) ->field(’f.name,f.egif,d.position’)->find(); $gift_infonum[’num’] = $v; $list[’gift’][] = array_merge($gift_info, $gift_infonum); $desireLog = Db::connect(’db_qmconfig’)->name(’desire_log’)->insert($data); $userKnapsack = Db::connect(’db_qmconfig’)->name(’gift_knapsack’)->where([’uid’ => $userData[’id’], ’giftid’ => $k])->field(’id,num’)->find(); if ($userKnapsack) { $userKnapsackData = [ ’num’ => $v + $userKnapsack[’num’], ’updatetime’ => time() ]; $userKnapsackUpdate = Db::connect(’db_qmconfig’)->name(’gift_knapsack’)->where([’id’ => $userKnapsack[’id’]])->update($userKnapsackData); } else { $userKnapsackData = [ ’num’ => $v, ’giftid’ => $k, ’uid’ => $userData[’id’], ’createtime’ => time() ]; $userKnapsackInsert = Db::connect(’db_qmconfig’)->name(’gift_knapsack’)->insert($userKnapsackData); } }  ///增加用戶消費記錄 $userXfData = [ ’uid’ => $userData[’id’], ’xf_price’ => $sendNum, ’xf_method’ => 5, ’scene’ => 19, ’status’ => 1, ’ctime’ => time() ]; $userXf = Db::connect(’db_qmconfig’)->name(’xfprice’)->insert($userXfData); if ($desireLog && $userXf) {///扣除用戶金幣 $newDiamondsData = [ ’diamonds’ => $desireDiamonds[’diamonds’] - $sendNum ]; $newDiamonds = Db::connect(’db_qmconfig’)->name(’user_money’)->where([’uid’ => $userData[’id’]])->update($newDiamondsData); } if ($userRedis) { Cache::set(’用戶獎池名稱’ . $userData[’id’], serialize($userRedis));  ////如果此輪抽獎抽到大獎 重置用戶個人獎池 if ($gift_height == 1) { Cache::set(’用戶獎池名稱’ . $userData[’id’], serialize([])); $userChecksum = $res[’zongshu’][’checksum’] - ($res[’zongshu’][’user_num’] + $sendNum); $desireLogUserWhere = [ ’uid’ => $userData[’id’], ’giftid’ => 0, ’num’ => $userChecksum, ’ctime’ => time(), ’cid’ => $user_desire_log, ];///添加禮物抽中記錄 $desireLogUser = Db::connect(’db_qmconfig’)->name(’desire_log’)->insert($desireLogUserWhere); } $swhere[] = [’d.state’, ’=’, 1]; $swhere[] = [’d.kind’, ’=’, 1]; $res[’data’] = $this->giftInfo($swhere); if (empty($res[’data’])) { output(’1008’, ’獎池更新中’); }////獲取用戶此輪抽獎數量 返回給前端 控制獎池動畫百分比 $res[’zongshu’] = Db::connect(’db_qmconfig’) ->name(’desire’)->where([’state’ => 1, ’kind’ => 1]) ->field(’checksum as num’) ->find(); $user = Db::connect(’db_qmconfig’) ->name(’desire_log’)->where([’uid’ => $userData[’id’]]) ->field(’SUM(num) as num’) ->find(); $res[’diamonds’] = Db::connect(’db_qmconfig’) ->name(’user_money’)->where([’uid’ => $userData[’id’]]) ->value(’diamonds’); if ($user) { if ($user[’num’] > $res[’zongshu’][’num’]) { $res[’zongshu’][’user_num’] = $user[’num’] % $res[’zongshu’][’num’]; } else { $res[’zongshu’][’user_num’] = $user[’num’]; } } else { $res[’zongshu’][’user_num’] = 0; } $list[’info’] = $res; return $list;// return [’msg’=>$res[’zongshu’][’user_num’]]; } else {////如果當前用戶獎池抽完獎了 那么重置此用戶獎池 $where[] = [’d.state’, ’=’, 1]; $where[] = [’d.kind’, ’=’, 1]; $res = $this->giftInfo($where); if (empty($res)) { return [’msg’ => ’獎池更新中’]; } $c = []; foreach ($res as $m => $n) {///十抽必中獎品 if ($n[’ten’]==1){ $n[’num’] = $n[’num’] - $n[’checksum’]/10; $giftarr = array_fill(0, $n[’num’]+$n[’checksum’]/10, $suiji[’giftid’]); $c = array_merge($c, $giftarr); if ($n[’num’]<=0){ continue; } }///百抽必中獎品 if ($n[’hundred’]==1){ $n[’num’] = $n[’num’] - $n[’checksum’]/100; $giftarr = array_fill(0, $n[’num’]+$n[’checksum’]/100, $suiji[’giftid’]); $c = array_merge($c, $giftarr); if ($n[’num’]<=0){ continue; } } $giftarr = array_fill(0, $n[’num’], $n[’id’]); $c = array_merge($c, $giftarr); }///隨機打亂獎池 shuffle($c); Cache::set(’用戶獎池名稱’ . $userData[’id’], serialize($c)); if ($newNum>0){ ///遞歸此方法 抽剩下的獎品 return $this->draw($newNum); } } } else { ///如果沒有獎池 生成獎池 $where[] = [’d.state’, ’=’, 1]; $where[] = [’d.kind’, ’=’, 1]; $res = $this->giftInfo($where); if (empty($res)) { return [’msg’ => ’獎池更新中’]; } $c = []; foreach ($res as $m => $n) { if ($n[’ten’]==1){ $n[’num’] = $n[’num’] - $n[’checksum’]/10; $giftarr = array_fill(0, $n[’num’]+$n[’checksum’]/10, $suiji[’giftid’]); $c = array_merge($c, $giftarr); if ($n[’num’]<=0){ continue; } } if ($n[’hundred’]==1){ $n[’num’] = $n[’num’] - $n[’checksum’]/100; $giftarr = array_fill(0, $n[’num’]+$n[’checksum’]/100, $suiji[’giftid’]); $c = array_merge($c, $giftarr); if ($n[’num’]<=0){ continue; } } $giftarr = array_fill(0, $n[’num’], $n[’id’]); $c = array_merge($c, $giftarr); } shuffle($c); Cache::set(’用戶獎池名稱’ . $userData[’id’], serialize($c)); ///遞歸此方法抽獎 return $this->draw($num); } }?>

以上就是PHP實現抽獎功能實例代碼的詳細內容,更多關于PHP實現抽獎功能的資料請關注好吧啦網其它相關文章!

標簽: PHP
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
宅男在线一区| zzzwww在线看片免费| 正在播放日韩精品| 国内不卡的一区二区三区中文字幕| 麻豆一区二区三| 国产一区不卡| 亚洲无线一线二线三线区别av| 99精品99| 久久国产尿小便嘘嘘| 97久久亚洲| 精品国产91| 婷婷成人基地| 日韩精品免费视频人成| 国产精品毛片视频| 激情综合婷婷| 国产综合精品一区| 日本在线观看不卡视频| 国产欧美91| 日韩一区二区在线免费| 国产精品美女久久久| 国产一区 二区| 国产拍在线视频| 中文亚洲欧美| 国产精品美女在线观看直播| 国产一区二区三区网| 91久久在线| 美日韩一区二区三区| 欧美一区二区性| 7m精品国产导航在线| 精品捆绑调教一区二区三区 | 久久国内精品| 国产精品yjizz视频网| 99视频在线精品国自产拍免费观看| 日韩视频1区| 三级在线看中文字幕完整版| 亚洲婷婷丁香| 国产精品伦理久久久久久| 红桃视频国产一区| 日本欧美一区| 激情五月综合| 久久亚洲黄色| 中文字幕av一区二区三区人| 国产网站在线| 日韩精品高清不卡| 亚洲午夜电影| 国产精品**亚洲精品| 亚洲专区欧美专区| 精品理论电影在线| 日韩中文字幕无砖| 欧美亚洲国产精品久久| 国产精品一站二站| 中国女人久久久| 国产一区二区三区视频在线| 丝袜美腿一区二区三区| 在线天堂资源www在线污| 日韩高清一区在线| 黄色日韩在线| 成人午夜精品| 美女精品视频在线| 亚洲毛片一区| 激情婷婷亚洲| 成人av三级| 美女国产精品久久久| 亚洲精品乱码| 日韩午夜免费| 99精品在线观看| 91综合网人人| 麻豆精品视频在线观看免费| 日韩精品一级中文字幕精品视频免费观看 | 欧美一区二区三区免费看| 亚洲天堂黄色| 日韩国产专区| 精品三级av| 国产日韩高清一区二区三区在线 | 免费不卡在线观看| 性欧美xxxx免费岛国不卡电影| 国产aa精品| 国产精品一区二区精品视频观看 | 欧美在线影院| 播放一区二区| 日韩在线二区| av中文资源在线资源免费观看| 国产精品一区高清| 欧美精品中文字幕亚洲专区| 亚洲丝袜啪啪| 美女网站久久| 久久性天堂网| 蜜臀av一区二区三区| 在线亚洲精品| 亚洲一区二区网站| 麻豆91精品| 亚洲综合日本| 中文无码日韩欧| 婷婷视频一区二区三区| 婷婷成人av| 日本欧美久久久久免费播放网| 婷婷亚洲成人| 91欧美极品| 国产激情久久| 欧美精品不卡| 色爱综合网欧美| 色老板在线视频一区二区| 在线一区视频观看| 五月婷婷亚洲| 免播放器亚洲| 日韩综合一区二区| 国产精一区二区| 久久a爱视频| 国产精品久久观看| 久久国产电影| 蜜臀av性久久久久蜜臀aⅴ四虎| 综合激情网站| 欧美日韩亚洲三区| 精品国产aⅴ| 亚洲黄色免费看| 国产综合亚洲精品一区二| 日韩视频在线一区二区三区| 蜜臀国产一区二区三区在线播放| 亚洲免费成人av在线| 久久国产三级| 成人在线视频中文字幕| 久久中文字幕av一区二区不卡| 黄色国产精品| 人人精品久久| 日产午夜精品一线二线三线| 99久久婷婷这里只有精品| 丝袜国产日韩另类美女| 欧美另类中文字幕| 福利一区二区三区视频在线观看| 日韩电影免费在线观看| 99综合视频| 国产精品极品| 欧美精品一区二区久久| 日韩高清在线不卡| 水蜜桃精品av一区二区| 国产高清一区二区| 18国产精品| 久久蜜桃av| 久久国内精品自在自线400部| 高潮久久久久久久久久久久久久| 好吊日精品视频| 国产精品白丝久久av网站| 99视频精品视频高清免费| 日本不卡视频在线| 欧美一级鲁丝片| 亚洲精品乱码| 国产美女高潮在线观看| 蜜臀a∨国产成人精品| 久久av影视| 欧美日韩国产免费观看| 国产精品综合| 亚洲欧洲日本mm| 久久亚洲资源中文字| 老鸭窝毛片一区二区三区| 精品视频一区二区三区在线观看 | 婷婷久久免费视频| 蜜桃av.网站在线观看| 亚洲精品伊人| 久久久国产亚洲精品| 欧美久久亚洲| 99在线观看免费视频精品观看| 麻豆高清免费国产一区| 国产亚洲高清视频| sm久久捆绑调教精品一区| 97精品久久| 亚洲激情中文| 四虎成人av| 国产丝袜一区| 日韩一区精品字幕| 91欧美在线| 国产精品三p一区二区| 中文在线不卡| 亚洲播播91| 国内精品亚洲| 国产麻豆一区二区三区 | 在线亚洲免费| 欧产日产国产精品视频| 国产欧美日韩一级| 综合视频一区| 中文亚洲欧美| 成人av动漫在线观看| 日韩精品电影| 狠狠久久伊人中文字幕| 天堂va欧美ⅴa亚洲va一国产| 欧美日韩免费观看一区=区三区| 福利一区二区免费视频| 国产精品3区| 青青国产91久久久久久| 亚洲一区二区免费在线观看| 9色国产精品| 午夜久久99| 国产高清一区| 亚洲第一精品影视| 99国产精品一区二区| 国产aa精品| 国产一区二区三区不卡视频网站 | 久久中文字幕av一区二区不卡| 色婷婷综合网| 高潮久久久久久久久久久久久久| 美女在线视频一区|