本文實例講述了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日期與時間用法總結》、《PHP數組(Array)操作技巧大全》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。