php基于登陸時間判斷實現(xiàn)一天多次登錄只積分一次功能示例
本文實例講述了php基于登陸時間判斷實現(xiàn)一天多次登錄只積分一次功能。分享給大家供大家參考,具體如下:
在網(wǎng)上找了很多的案例,感覺都差不多,有的還比較的繁瑣,就自己嘗試了一下,如何實現(xiàn)這個功能
實現(xiàn)這個功能我在數(shù)據(jù)表里面增加了一個字段logintime,表示最后一次的登錄時間,然后使用一天中的零時零分零秒和上一次的登錄時間進行比較,如果上一次的登錄時間大于了這個時間點表示已經(jīng)登陸過,如果上一次的登錄時間小于了這個時間點,則表示第一次登錄,增加積分
上代碼:
// 判斷是否是一天中第一次登錄
// 上一次登陸的時間
$lastLogintime = $userinfo['logintime'];
// 一天中的零時零分零秒
$today = strtotime(date('Y-m-d'));
if($lastLogintime < $today) {
// 一天中第一次登錄增加積分(關(guān)聯(lián)更新)
// 注意:使用關(guān)聯(lián)更新數(shù)據(jù)的時候需要傳遞兩次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);
這樣就實現(xiàn)了這個功能
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php日期與時間用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設(shè)計有所幫助。
相關(guān)文章
php使用自定義函數(shù)實現(xiàn)漢字分割替換功能示例
這篇文章主要介紹了php使用自定義函數(shù)實現(xiàn)漢字分割替換功能,結(jié)合實例形式分析了php針對漢字的遍歷、轉(zhuǎn)換與分割操作相關(guān)技巧,需要的朋友可以參考下2017-01-01
php實現(xiàn)的仿阿里巴巴實現(xiàn)同類產(chǎn)品翻頁
當(dāng)前頁左邊的頁碼為最新的產(chǎn)品,按更新時間呈升序排列;右邊的頁碼為早期的產(chǎn)品, 按更新時間呈降序排列。2009-12-12
php數(shù)組函數(shù)array_walk用法示例
這篇文章主要介紹了php數(shù)組函數(shù)array_walk用法,分析了array_walk對數(shù)組中每個成員調(diào)用用戶函數(shù)的使用技巧,需要的朋友可以參考下2016-05-05
php編寫的mysqli增刪改查數(shù)據(jù)庫操作類示例
這篇文章主要為大家介紹了php編寫的mysqli增刪改查數(shù)據(jù)庫操作類示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-08-08

