Laravel框架实现抢红包功能示例
本文实例讲述了Laravel框架实现抢红包功能。分享给大家供大家参考,具体如下:
首先进行登录
{{csrf_field()}} 用户名:
密 码:
在登录时,我们会进行一些相应的验证:比如用户名,手机号,密码等–
//登录 publicfunctionlogin(){ if(Request()->isMethod('get')){ returnview('Bonus/login'); }elseif(Request()->isMethod('post')){ $info=Request()->only('username','password');//这里为接收的表单数据 $result=BonusModel::b_login($info);//调用模型,进行验证 if($result['status']==200){ returnredirect('b_user'); } } }
模型部分代码
//登录 publicstaticfunctionb_login($info){ $result=DB::table('bonus_user')->where('username',$info['username'])->first(); if(empty($result)){ $res['status']=201; $res['message']='用户不存在'; }else{ if(md5($info['password'])!=$result->password){ $res['status']=202; $res['message']='密码错误'; }else{ Session::put('uid',$result->id); $res['status']=200; $res['message']='登录成功'; } } return$res; }
登录成功之后,跳转到了用户信息的页面
可以在信息界面自行选择抢红包或者发红包
1.发红包,跳转到相应的发红包界面
输入要发的个数和总金额,然后进行发红包
//控制器部分代码 //发红包 publicfunctionsendRecord(){ if(Request()->isMethod('get')){ returnview('Bonus/bonus'); }elseif(Request()->isMethod('post')){ $data=Request()->all(); $result=BonusModel::send($data); if($result['status']==200){ returnredirect('b_user')->with('msg',$result['message']);; }else{ returnredirect('b_user')->with('msg',$result['message']); } } } //发红包(模型部分代码) publicstaticfunctionsend($data){ $id=Session::get('uid');//取出session中存储的id信息 $user=DB::select("selectmoneyfrombonus_userwhereid=$id");//根据id查询出相应的用户信息 if($user[0]->money<$data['amount']){//判断发红包的金额和用户的余额 $result['status']=203; $result['message']="余额不足"; return$result;die; }else{ $total=$data['amount'];//发送的总金额 $nums=$data['nums'];//红包个数 $min=0.01;//最少领导0.01元 $redRecord=[];//定义一个空数组,存储每个红包金额 for($i=1;$i<$nums;$i++){ $safe_total=($total-($nums-$i)+$min)/($nums-$i);//随机金额上限 $money=mt_rand($min*100,$safe_total*100)/100; $total=$total-$money; $redRecord[]=array( 'money'=>$money,'uid'=>$id,'create_time'=>date('Y-m-dH:i:s') ); } $redRecord[$nums-1]=array('money'=>$total,'uid'=>$id,'create_time'=>date('Y-m-dH:i:s')); $redarr=array('uid'=>$id,'total'=>$data['amount'],'nums'=>$data['nums'],'create_time'=>date('Y-m-dH:i:s')); DB::table('bonus_record')->insert($redarr);//那个用户发的红包,金额数,个数 $info=DB::table('bonus')->insert($redRecord);//红包详细,使用情况 DB::table('bonus_user')->where('id',$id)->decrement('money',$data['amount']); if($info){ $result['status']=200; $result['message']="发送成功"; return$result; }else{ $result['status']=201; $result['message']="发送失败"; return$result; } } }
发送红包之后,返回到用户信息页面,我们可以看到,用户的余额会变少,减少的金额为红包的总额
发送之后,相应的数据已经入了库表,此时我们可以进行抢红包
//控制器部分代码 //抢红包 publicfunctionHitBonus(){ $result=BonusModel::hit();//调用模型 if($result['status']==200){ returnredirect('b_user')->with('msg',$result['message']);//带信息的重定向 }else{ returnredirect('b_user')->with('msg',$result['message']); } } //模型部分代码 //抢红包 publicstaticfunctionhit(){ //检测是否登录 if(!Session::has('uid')){ $result['status']=206; $result['message']="登录之后再来抢红包"; return$result; } $count=DB::table('bonus')->where('did',Session::get('uid'))->count(); if($count>=1){ $result['status']=208; $result['message']="您已经抢过红包了"; return$result; } $data=DB::table('bonus')->where('status',0)->first();//查询出没有被抢的红包 if(empty($data)){//如果没有状态为0的红包,说明所有的红包都已经被抢了 $result['status']=205; $result['message']="您来晚了,红包已经没有了"; return$result; }else{//如果还有红包 $array=array( 'status'=>1,//改变红包的状态 'did'=>Session::get('uid'),//抢红包用户的id 'update_time'=>date('Y-m-dH:i:s')//抢红包的时间 ); $info=DB::table('bonus')->where('rid',$data->rid)->update($array); if($info){ $res=DB::table('bonus_user')->where('id',Session::get('uid'))->first();//查询抢红包用户的信息 $money=$res->money+$data->money;//原金额加上抢到的金额 $array=array('money'=>$money); $resu=DB::table('bonus_user')->where('id',Session::get('uid'))->update($array); $hit_money=$data->money; if($resu){ $result['status']=200; $result['message']="恭喜您抢到:'".$hit_money."'"; return$result; } } } }
我们可以看抢红包的效果
抢红包成功之后,用户余额会加上抢到的金额
再次点击抢红包之后
会提示您已经抢过红包了
这就是一个简单的抢红包~~~
更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。