在项目开发中经常会遇到花钱抽奖类型的需求。但是老板总是担心用户用小钱抽到大奖。这样会导致项目亏损。下边这段代码可以有效制止抽奖项目亏钱。

个人奖池:

语言:thinkphp redis mysql

表:desire抽奖商品表 desire_log用户抽奖奖品表 user_desire_log用户抽奖记录表   desire_risk抽奖风控表

需求:用户奖池分为进行中奖池 和已完成奖池 当用户抽到大奖后 用户个人奖池重置 否则将继续抽奖 最后一次抽奖必中大奖 通过风控金额来判断用户是否可以抽大奖

当所有用户已完成的抽奖 盈利大于风控金额的时候可以让用户抽大奖 否则用户抽不到大奖

//抽奖接口

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 mysql随机抽奖源码_PHP实现抽奖功能实例代码相关推荐

  1. 视频直播app源码,动态发布功能模块代码

    视频直播app源码中,不仅有"视频直播模块",还有"业务模块""消息模块"等等,其中,在动态发布功能里,选择图片后查看及删除的功能该怎么做呢 ...

  2. php mysql表单源码_PHP表单数据写入MySQL数据库的代码

    废话不多说了,直接给大家贴代码了,具体代码如下所示: if(!isset($_POST['submit'])){ //如果没有表单提交,显示一个表单 ?> 国家: 动物名称(英文): 动物名称( ...

  3. php mysql网站统计源码_php统计器代码(在线人数据统计程序源码)

    这种一款可以统计你网站当前在线人数的代码哦,由php+txt实现的无需数据来来支持. $time = gettimeofday(void); //文件初始化 start if(@filesize(&q ...

  4. php答题抽奖源码,PHP转盘抽奖接口实例

    本文实例讲述了PHP转盘抽奖接口的实现方法.分享给大家供大家参考.具体如下: 这里的转盘抽奖随机返回一个转盘角度,概率可自己定义 lottery_get.php接口文件如下: /*session_st ...

  5. 石头剪刀布php源码,微信小程序 石头剪刀布实例代码

    搜索热词 微信小程序 石头剪刀布 昨天看有个石头剪刀布的练习,就拿出来做了一下,布局的代码浪费了很多时间,果然CSS这块的还不是很熟练,下面直接上图上代码了. .js: //获取数组中用户的,石头剪刀 ...

  6. php mysql抽奖转盘_thinkphp 微信抽奖源码PHP前后台+转盘+数据库完整示例

    [实例简介]1微信抽奖源码PHP前后台 转盘 数据库完整示例 [实例截图] [核心代码]1微信抽奖源码PHP前后台 转盘 数据库完整示例 // 本类由系统自动生成,仅供测试用途 class Index ...

  7. Python+HTML随机点名抽奖源码模板

    介绍: 一款不错的Python+HTML随机点名抽奖源码模板,带背景音乐,bootstrap框架自适应手机端,随机数据在others.js里面增加修改. 网盘下载地址: http://kekewl.c ...

  8. 盲盒拓客商家联盟红包裂变抽奖源码

    盲盒拓客商家联盟红包裂变抽奖源码 简介: 盲盒拓客,集五种玩法于一身!.盲盒一刺激!好奇心!.商家联盟一多商家推广,扩人传播覆盖群体.红包拓客一促进分销裂变.抽奖一概率事件,随机中奖.言舌动分销裂变平 ...

  9. cocos2dx 圆盘抽奖_cocos2d编写的类似幸运大转盘抽奖源码

    压缩包内容概览: cocos2d编写的类似幸运大转盘抽奖源码-帮你选择 ; 随机 ; 程序委托 ; 背高清 ; 背 ipad ; 返回 ; 默认 ; 默认@2x ; 图标-72 ; 图标@2x ; 我 ...

最新文章

  1. python进阶:JSON与枚举
  2. java swt webkit_使用Java和Webkit的HTML编辑器 – SWT浏览器
  3. Cocos2d-x v2.2.2版本+Win7+VS2010环境搭建
  4. Sublime Text 2 入门技巧
  5. db2 springboot 整合_[SpringBoot]快速配置多数据源(整合MyBatis)
  6. STM8单片机ADC连续采样模式
  7. php更新不了数据库,为什么我不能使用PHP编辑/更新数据库?
  8. CGAL 4.9 - Triangulated Surface Mesh Deformation
  9. Luogu3431 [POI2005]AUT-The Bus
  10. 疯狂突破高中句型300句
  11. SDUT 1160 某年某月的天数
  12. html中output标签详细介绍
  13. 数控弯管机xyz转换ybc的算法_数控弯管机技术的更新和应用.pdf
  14. 用计算机排序excel,【用excel名字排序的方法有哪些?这些简便的计算机技能你一定需要】- 环球网校...
  15. Caché 命令大全
  16. 怎么关闭excel出现的microsoft office 自定义安装程序提示
  17. 出现BOOTMGR is missing 最简单实用的解决方案
  18. 有什么占内存小又好玩的手游,占内存小的手机游戏
  19. 好程序员云计算培训分享云计算中微服务是什么?
  20. 如何用ghost备份linux,Linux如何用Ghost备份Linux系统?

热门文章

  1. 2048小游戏APP
  2. 源码分享意义何在?为何很多官方软件开发商都会有破解版和bug版本的系统盛行?
  3. 用PDF阅读器实现PDF合并及PDF拆分技巧
  4. Fluent动网格【8】:网格节点运动案例
  5. 新增网址/网页 截图api[增加安全防护本接口已停用]源码可下载
  6. Project 2010 架构图
  7. Arduino(2560)控制两个步进电机通过控制器
  8. 把Font Awesome引入到自己的项目中
  9. 2021最新Java面试真题解析!java写九九乘法表代码
  10. HTML_04_表单_框架