Table des matières
Articles qui pourraient vous intéresser. dans :
Maison développement back-end tutoriel php Explication détaillée d'un exemple d'analyse de méthodes pour implémenter la fonction de connexion en PHP

Explication détaillée d'un exemple d'analyse de méthodes pour implémenter la fonction de connexion en PHP

Jul 07, 2018 pm 05:56 PM
php 签到

Cet article présente principalement la méthode d'implémentation de la fonction d'enregistrement en PHP et analyse les techniques associées de PHP pour implémenter la fonction d'enregistrement basée sur la base de données et l'opération de jugement temporel sous forme d'exemples. peut se référer à ce qui suit

Les exemples de cet article expliquent comment implémenter la fonction d'enregistrement en PHP. Je le partage avec vous pour votre référence. Les détails sont les suivants :

Tout d'abord, j'ai construit deux tables dans la base de données. L'une est la table des points de l'utilisateur et l'autre est la table du statut d'enregistrement. Les points sont utilisés pour enregistrer les points de l'utilisateur et le statut de première arrivée

Dans le tableau du statut de connexion de l'utilisateur, nous avons un champ, last_sign_time, qui est la dernière heure de connexion, et vous pouvez vous connecter à chaque fois. Lorsque vous comparez cette heure avec l'heure actuelle, si la différence est de 0 jour, cela signifie que vous vous êtes enregistré aujourd'hui (cet enregistrement ne peut être effectué que une fois toutes les 24 heures, c'est-à-dire que la différence entre les deux enregistrements doit être supérieure à 24 heures). Si cela est égal à un jour, cela signifie aujourd'hui. Vous pouvez vous connecter. Si cela fait 2 jours ou plus, cela signifie vous avez manqué le signe.

Sur la base du jugement de l'horodatage, la table d'état est mise à jour en temps opportun, et lorsqu'il est possible de se connecter, la table des points utilisateur est exploitée, c'est-à-dire l'utilisateur. les points sont mis à jour.

Le code spécifique est le suivant :

<?php
$user_id=@$_REQUEST[&#39;user_id&#39;];
//功能:计算两个时间戳之间相差的日时分秒
//$begin_time 开始时间戳
//$end_time 结束时间戳
function timediff($begin_time,$end_time)
{
   if($begin_time < $end_time){
     $starttime = $begin_time;
     $endtime = $end_time;
   }else{
     $starttime = $end_time;
     $endtime = $begin_time;
   }
   //计算天数
   $timediff = $endtime-$starttime;
   $days = intval($timediff/86400);
   //计算小时数
   $remain = $timediff%86400;
   $hours = intval($remain/3600);
   //计算分钟数
   $remain = $remain%3600;
   $mins = intval($remain/60);
   //计算秒数
   $secs = $remain%60;
   $res = array("day" => $days,"hour" => $hours,"min" => $mins,"sec" => $secs);
   return $res;
}
function upuserscore($current_total_day){
$user_id=@$_REQUEST[&#39;user_id&#39;];
//读取数据库配置信息的ini文件
  $ary=parse_ini_file(&#39;db.ini&#39;);
  $db_login_name=base64_decode($ary[&#39;db_login_name&#39;]);
  $db_login_password=base64_decode($ary[&#39;db_login_password&#39;]);
  $db_host=base64_decode($ary[&#39;db_host&#39;]);
  $db_name=base64_decode($ary[&#39;db_name&#39;]);
//链接数据库
 $scorelink=mysqli_connect($db_host,$db_login_name,$db_login_password);
mysqli_select_db($scorelink,$db_name); //选择数据库
//检查积分表里是否有该用户 有的话则更新数据 没有的话则插入数据
$scoreq = "SELECT * FROM user_score WHERE user_id=$user_id"; //SQL插入语句
    mysqli_query($scorelink,"SET NAMES utf8");
    $rs = mysqli_query($scorelink,$scoreq); //获取数据集
    if(!$rs){
        exit(json_encode(array(&#39;status&#39;=>"success",&#39;code&#39;=>"1",&#39;error&#39;=>mysqli_error($scorelink))));
    }
    if(mysqli_num_rows($rs)){//该用户有数据 则更新其积分信息
      $total_score="";
       while($row = mysqli_fetch_row($rs)) {
      $total_score=$row[4];
      }
      $scoreusdateq = "UPDATE user_score SET user_total_score =&#39;98&#39; WHERE user_id=$user_id;"; //更新
      mysqli_query($scorelink,"SET NAMES utf8");
      $ustaters = mysqli_query($scorelink,$scoreusdateq); //获取数据集
      if($ustaters ==1){
          exit(json_encode(array(&#39;status&#39;=>"success",&#39;code&#39;=>"100")));
        mysqli_close($scorelink);//关闭连接  
        exit();
      }else{
          exit(json_encode(array(&#39;status&#39;=>"success",&#39;code&#39;=>"1")));
           mysqli_close($scorelink);//关闭连接
           exit();
      }
    }else{//没有该用户数据 则插入其积分信息
      $scoreinsertq = "insert into user_score (user_id,user_total_score)values($user_id,10)"; //SQL插入语句
      mysqli_query($scorelink,"SET NAMES utf8");
      $rs = mysqli_query($scorelink,$scoreinsertq); //获取数据集
      if(!$rs){
          exit(json_encode(array(&#39;status&#39;=>"success",&#39;code&#39;=>"1",&#39;error&#39;=>mysqli_error($scorelink))));
      }
      if(strpos($q,"SELECT") === false){
          exit(json_encode(array(&#39;status&#39;=>"success",&#39;code&#39;=>"100")));
      }
      mysqli_close($scorelink);//关闭连接
    }
}
//读取数据库配置信息的ini文件
  $ary=parse_ini_file(&#39;db.ini&#39;);
  $db_login_name=base64_decode($ary[&#39;db_login_name&#39;]);
  $db_login_password=base64_decode($ary[&#39;db_login_password&#39;]);
  $db_host=base64_decode($ary[&#39;db_host&#39;]);
  $db_name=base64_decode($ary[&#39;db_name&#39;]);
//链接数据库
 $link=mysqli_connect($db_host,$db_login_name,$db_login_password);
mysqli_select_db($link,$db_name); //选择数据库
//检查签到表里是否有该用户 有的话则更新数据 没有的话则插入数据
$q = "SELECT * FROM user_signin WHERE user_id=$user_id"; //SQL插入语句
    mysqli_query($link,"SET NAMES utf8");
    $rs = mysqli_query($link,$q); //获取数据集
    if(!$rs){
        exit(json_encode(array(&#39;status&#39;=>"success",&#39;code&#39;=>"1",&#39;error&#39;=>mysqli_error($link))));
    }
    if(mysqli_num_rows($rs)){//该用户有数据 则更新其签到信息
      $last_time="";
      $total_day="";
       while($row = mysqli_fetch_row($rs)) {
      $last_time=$row[4]."<br/>";
      $total_day=$row[5];
    }
      //根据上次签到时间和这次签到时间作比较判断有没有漏签和今日是否已签到
      $current_total_day=intval($total_day)+1;
      $current_day=time();
      $ary = timediff($last_time,$current_day);
    if($ary[day]==0){//今天已签到
       exit(json_encode(array(&#39;status&#39;=>"success",&#39;code&#39;=>"5")));
        mysqli_close($link);//关闭连接  
        exit();
    }else if($ary[day]==1){//没有漏签
      $usdateq = "UPDATE user_signin SET last_sign_time=&#39;$current_day&#39;, total_day=&#39;$current_total_day&#39; WHERE user_id=$user_id;"; //更新
      mysqli_query($link,"SET NAMES utf8");
      $ustaters = mysqli_query($link,$usdateq); //获取数据集
      if($ustaters ==1){
      upuserscore($current_total_day);
          //exit(json_encode(array(&#39;status&#39;=>"success",&#39;code&#39;=>"100")));
        mysqli_close($link);//关闭连接  
        exit();
      }else{
          exit(json_encode(array(&#39;status&#39;=>"success",&#39;code&#39;=>"1")));
           mysqli_close($link);//关闭连接
         exit();
      }
    }else{//漏签过
    $usdateq = "UPDATE user_signin SET last_sign_time=&#39;$current_day&#39;, total_day=1 WHERE user_id=$user_id;"; //更新
    mysqli_query($link,"SET NAMES utf8");
    $ustaters = mysqli_query($link,$usdateq); //获取数据集
    if($ustaters ==1){
      upuserscore($current_total_day);
        //exit(json_encode(array(&#39;status&#39;=>"success",&#39;code&#39;=>"100")));
      mysqli_close($link);//关闭连接  
      exit();
    }else{
        exit(json_encode(array(&#39;status&#39;=>"success",&#39;code&#39;=>"1")));
       mysqli_close($link);//关闭连接
       exit();
    }
  }
  }else{//没有该用户记录则插入
    $current_day=time();
    $insertq = "insert into user_signin (user_id,last_sign_time,total_day)values($user_id,&#39;$current_day&#39;,1)"; //SQL插入语句
    mysqli_query($link,"SET NAMES utf8");
    $insertrs = mysqli_query($link,$insertq); //获取数据集
    if(strpos($insertrs,"SELECT") === false){//出入数据成功
      upuserscore(&#39;1&#39;);
      //exit(json_encode(array(&#39;status&#39;=>"success",&#39;code&#39;=>"100")));
      }
  }
  mysqli_close($link);//关闭连接
?>
Copier après la connexion

Articles qui pourraient vous intéresser. dans :

Explication détaillée de la résolution du problème d'épuisement de la mémoire causé par un trop grand nombre de processus php-fpm sous Linux

Explication détaillée d'un exemple d'analyse de la façon dont php implémente la fonction d'enregistrement

Introduction détaillée à la configuration des paramètres php-fpm et aux instructions d'optimisation des paramètres sous Linux

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

Date et heure de CakePHP Date et heure de CakePHP Sep 10, 2024 pm 05:27 PM

Pour travailler avec la date et l'heure dans cakephp4, nous allons utiliser la classe FrozenTime disponible.

Téléchargement de fichiers CakePHP Téléchargement de fichiers CakePHP Sep 10, 2024 pm 05:27 PM

Pour travailler sur le téléchargement de fichiers, nous allons utiliser l'assistant de formulaire. Voici un exemple de téléchargement de fichiers.

Discuter de CakePHP Discuter de CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP est un framework open source pour PHP. Il vise à faciliter grandement le développement, le déploiement et la maintenance d'applications. CakePHP est basé sur une architecture de type MVC à la fois puissante et facile à appréhender. Modèles, vues et contrôleurs gu

CakePHP créant des validateurs CakePHP créant des validateurs Sep 10, 2024 pm 05:26 PM

Le validateur peut être créé en ajoutant les deux lignes suivantes dans le contrôleur.

Journalisation CakePHP Journalisation CakePHP Sep 10, 2024 pm 05:26 PM

Se connecter à CakePHP est une tâche très simple. Il vous suffit d'utiliser une seule fonction. Vous pouvez enregistrer les erreurs, les exceptions, les activités des utilisateurs, les actions entreprises par les utilisateurs, pour tout processus en arrière-plan comme cronjob. La journalisation des données dans CakePHP est facile. La fonction log() est fournie

Comment configurer Visual Studio Code (VS Code) pour le développement PHP Comment configurer Visual Studio Code (VS Code) pour le développement PHP Dec 20, 2024 am 11:31 AM

Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

Guide rapide CakePHP Guide rapide CakePHP Sep 10, 2024 pm 05:27 PM

CakePHP est un framework MVC open source. Cela facilite grandement le développement, le déploiement et la maintenance des applications. CakePHP dispose d'un certain nombre de bibliothèques pour réduire la surcharge des tâches les plus courantes.

See all articles