本文实例讲述了Laravel框架实现抢红包功能。分享给大家供大家参考,具体如下:
首先进行登录
<form action="{{url('b_login')}}" method="post">
{{csrf_field()}}
<p>用户名:<input type="text" name="username"></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');
}elseif(Request()->isMethod('post')){
$info = Request()->only('username','password');//这里为接收的表单数据
$result = BonusModel::b_login($info);//调用模型,进行验证
if($result['status']==200){
return redirect('b_user');
}
}
}
模型部分代码
//登录
public static function b_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.发红包,跳转到相应的发红包界面

输入要发的个数和总金额,然后进行发红包
//控制器部分代码
//发红包
public function sendRecord(){
if(Request()->isMethod('get')){
return view('Bonus/bonus');
}elseif(Request()->isMethod('post')){
$data = Request()->all();
$result = BonusModel::send($data);
if($result['status']==200){
return redirect('b_user')->with('msg',$result['message']);;
}else{
return redirect('b_user')->with('msg',$result['message']);
}
}
}
//发红包(模型部分代码)
public static function send($data){
$id = Session::get('uid');//取出session中存储的id信息
$user = DB::select("select money from bonus_user where id = $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-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')->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;
}
}
}
内容版权声明:除非注明,否则皆为本站原创文章。
