本文實例講述了php基於登陸時間判斷實現一天多次登入只積分一次功能。分享給大家供大家參考,具體如下:
在網路上找了很多的案例,感覺都差不多,有的還比較的繁瑣,就自己嘗試了一下,如何實現這個功能
實作這個功能我在資料表裡面增加了一個欄位logintime,表示最後一次的登入時間,然後使用一天中的零時零分零秒和上一次的登入時間進行比較,如果上一次的登入時間大於了這個時間點表示已經登陸過,如果上一次的登入時間小於了這個時間點,則表示第一次登錄,增加積分
上碼:
// 判断是否是一天中第一次登录 // 上一次登陆的时间 $lastLogintime = $userinfo['logintime']; // 一天中的零时零分零秒 $today = strtotime(date('Y-m-d')); if($lastLogintime < $today) { // 一天中第一次登录增加积分(关联更新) // 注意:使用关联更新数据的时候需要传递两次id $data['id'] = $userinfo['id']; $data['userinfo'] = array( 'points' => $userinfo['points'] + C('LOGIN'), ); $user->relation(true)->where(array('id'=>$userinfo['id']))->save($data); }
要注意的是還要修改登入時間:
// 更新登录时间和登录ip $updateData = array( 'id' => $userinfo['id'], 'userinfo' => array( 'logintime' => time(), 'loginip' => getIP(), ), ); $user->relation(true)->where(array('id'=>$userinfo['id']))->save($updateData);
這樣就實作了這個功能
以上是php實作一天多次登入只積分一次功能的實作範例的詳細內容。更多資訊請關注PHP中文網其他相關文章!