您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關php如何實現每天積分加一的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
php實現每天積分加一的方法:1、在數據表里增加一個字段logintime;2、使用一天中的零時零分零秒和上一次的登錄時間進行比較;3、通過“if($lastLogintime < $today) {...}”實現積分增加即可。
本文操作環境:Windows7系統,PHP7.4版,Dell G3電腦。
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如何實現每天積分加一”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。