{{csrf " />
本文实例讲述了laravel框架实现抢红包功能。分享给大家供大家参考,具体如下:
首先进行登录
<form action="{{url('b_login')}}" method="post">{{csrf_field()}}<p>用户名:<input type="text" name="urname"></p><p>密码:<input type="password" name="password"></p><p><input type="submit" value="登录"></p></form>
在登录时,我们会进行一些相应的验证:比如用户名,手机号,密码等–
//登录public function login(){if(request()->ismethod('get')){return view('bonus/login');}elif(request()->ismethod('post')){$info = request()->only('urname','password');//这里为接收的表单数据$result = bonusmodel::b_login($info);//调用模型,进行验证if($result['status']==200){return redirect('b_ur');}}}
模型部分代码
//登录public static function b_login($info){$result = db::table('bonus_ur')->where('urname',$info['urname'])->first();if(empty($result)){$res['status'] = 201;$res['message'] = '用户不存在';}el{if(md5($info['password']) != $result->password){$res['status'] = 202;$res['message'] = '密码错误';}el{ssion::put('uid',$result->id);$res['status'] = 200;$res['message'] = '登录成功';}}return $res;}
登录成功之后,跳转到了用户信息的页面
可以在信息界面自行选择 抢红包 或者 发红包
1.发红包,跳转到相应的发红包界面
输入要发的个数和总金额,然后进行发红包
//控制器部分代码//发红包public function ndrecord(){if(request()->ismethod('get')){return view('bonus/bonus');}elif(request()->ismethod('post')){$data = request()->all();$result = bonusmodel::nd($data);if($result['status']==200){return redirect('b_ur')->with('msg',$result['message']);;}el{return redirect('b_u印象丽江r')->with('msg',$result['message']);}}}//发红包(模型部分代码) public static function nd($data){ $id = ssion::get('uid');//取出ssion中存储的id信息 $ur = db::lect("lect money from bonus_ur where id = $id");//根据id查询出相应的用户信息 if($ur[0]->money<$data['amount']){//判断发红包的金额 和 用户的余额 $result['status'] = 203; $result['message'] = "余额不足"; return $result;die; }el{ $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-根号16等于多少$money; $redrecord[] = array( 'money'=>$money,'uid'=>$id,'create_time'=>date('y-m-d h:i:s') ); } $redrecord[$nums-1] = array('money'=>$total,'uid'=>$id,'create_time'=>date('y-m-d h:i:s')); $redarr = array('uid'=>$id,'total'=>$data['amount'],'nums'=>$data['nums'],'create_time'=>date('y-m-d h:i:s')); db::table('bonus_record')->inrt($redarr);//那个用户发的红包,金额数,个数 $info = db::table('bonus')->inrt($redrecord);//红包详细,使用情况 db::table('bonus_ur')->where('id',$id)->decrement('money',$data['amount晒后修复方法']); if($info){ $result['status'] = 200; $result['message'] = "发送成功"; return $result; }el{ $result['status'] = 201; $result['message'] = "发送失败"; return $result; } } }
发送红包之后,返回到用户信息页面,我们可以看到,用户的余额会变少,减少的金额为红包的总额
发送之后,相应的数据已经入了库表,此时我们可以进行抢红包
//控制器部分代码//抢红包 public function hitbonus(){ $result = bonusmodel::hit();//调用模型 if($result['status']==200){ return redirect('b_ur')->with('msg',$result['message']);//带信息的重定向 }el{ return redirect('b_ur')->with('msg',$result['message']); } } //模型部分代码 //抢红包 public static function hit(){ //检测是否登录 if(!ssion::has('uid')){ $result['status']=206; $result['message']="登录之后再来抢红包"; return $result; } $count = db::table('bonus')->where('did',ssion::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; }el{//如果还有红包 $array = array( 'status'=>1,//改变红包的状态 'did' =>ssion::get('uid'),//抢红包用户的id 'update_time'=>date('y-m-d h:i:s')//抢红包的时间 ); $info = db::table('bonus')->where('rid',$data->rid)->update($array); if($info){ $res = db::table('bonus_ur')->where('id',ssion::get('uid'))->first();//查询抢红包用户的信息 $money = $res->money + $data->money;//原金额加上抢到的金额 $array = array('money'=>$money); $resu = db::table('bonus_ur')->where('id',ssion::get('uid'))->update($array); $hit_money = $data->money; if($resu){ $result['status'] = 200; $result['message'] = "恭喜您抢到:'".$hit_money."'"; return $result; } } } }
我们可以看抢红包的效果
抢红包成功之后,用户余额会加上抢到的金额
再次点击抢红包之后
会提示您已经抢过红包了
这就是一个简单的抢红包~~~
本文发布于:2023-04-08 07:54:42,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/727a270d732749f914ed5d14d5337826.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:Laravel框架实现抢红包功能示例.doc
本文 PDF 下载地址:Laravel框架实现抢红包功能示例.pdf
留言与评论(共有 0 条评论) |