首頁  >  文章  >  後端開發  >  php基於登陸時間判斷實現一天多次登入只積分一次功能

php基於登陸時間判斷實現一天多次登入只積分一次功能

不言
不言原創
2018-05-02 10:41:561225瀏覽

這篇文章主要介紹了php基於登陸時間判斷實現一天多次登入只積分一次功能,適合會員系統的積分功能,涉及php時間判斷與資料庫相關操作技巧,需要的朋友可以參考下

本文實例講述了php基於登陸時間判斷實現一天多次登入只積分一次功能。分享給大家供大家參考,具體如下:

在網路上找了很多的案例,感覺都差不多,有的還比較的繁瑣,就自己嘗試了一下,如何實現這個功能

實現這個功能我在資料表裡面增加了一個欄位logintime,表示最後一次的登入時間,然後使用一天中的零時零分零秒和上一次的登入時間進行比較,如果上一次的登入時間大於了這個時間點表示已經登陸過,如果上一次的登入時間小於了這個時間點,則表示第一次登錄,增加積分

#上碼:

##

// 判断是否是一天中第一次登录
// 上一次登陆的时间
$lastLogintime = $userinfo['logintime'];
// 一天中的零时零分零秒
$today = strtotime(date('Y-m-d'));
if($lastLogintime < $today) {
  // 一天中第一次登录增加积分(关联更新)
  // 注意:使用关联更新数据的时候需要传递两次id
  $data[&#39;id&#39;] = $userinfo[&#39;id&#39;];
  $data[&#39;userinfo&#39;] = array(
    &#39;points&#39; => $userinfo[&#39;points&#39;] + C(&#39;LOGIN&#39;),
  );
  $user->relation(true)->where(array(&#39;id&#39;=>$userinfo[&#39;id&#39;]))->save($data);
}

要注意的是也要修改登入時間:

// 更新登录时间和登录ip
$updateData = array(
  &#39;id&#39; => $userinfo[&#39;id&#39;],
  &#39;userinfo&#39; => array(
    &#39;logintime&#39; => time(),
    &#39;loginip&#39; => getIP(),
  ),
);
$user->relation(true)->where(array(&#39;id&#39;=>$userinfo[&#39;id&#39;]))->save($updateData);

這樣就實作了這個功能

#相關推薦:

PHP基於堆疊實作高階計算器功能詳解

以上是php基於登陸時間判斷實現一天多次登入只積分一次功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn