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(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。