Maison  >  Article  >  développement back-end  >  Optimiser les appels des clients vers les interfaces serveur pour réduire la capacité des données de requête

Optimiser les appels des clients vers les interfaces serveur pour réduire la capacité des données de requête

jacklove
jackloveoriginal
2018-06-09 09:09:521435parcourir

En raison des besoins du projet, il est nécessaire d'enregistrer le temps de réservation de l'utilisateur dans les 3 prochains jours, et chaque période de réservation est de 1 heure.

Par exemple : 00:00:00~00:59:59 ou 01:00:00~01:59:59 etc. sont considérés comme un période de réservation

Le code front-end est le suivant :

nbsp;HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">

 
  <meta>
  <title> 提交预约日期 </title>
  <style>
  .title{color:#FF0000;}
  .topic{font-size:18px; font-weight:bold;}
  </style>
  <script></script>
  <script>    function fsubmit(){
        var timetable = [];
        $("#myform input[type=checkbox]").each(function(){            if(this.checked){
                timetable.push($(this).val());
            }
        });        if(timetable.length==0){
            alert(&#39;请选择预约时间&#39;);
            return false;
        }
        $.post("http://localhost/server.php",{timetable:timetable}).done(function(data){            if(data[&#39;success&#39;]==true){
                alert(&#39;提交成功&#39;);                
            }else{
                alert(&#39;提交失败&#39;);
            }
        });
    }
  </script>
 
 
  <p>请选择预约时间:</p>
  
    

2015-05-28:

    

       00:00        01:00        02:00        03:00        04:00        05:00        06:00        07:00        08:00        09:00        10:00        11:00     

    

       12:00        13:00        14:00        15:00        16:00        17:00        18:00        19:00        20:00        21:00        22:00        23:00     

    

2015-05-29:

    

       00:00        01:00        02:00        03:00        04:00        05:00        06:00        07:00        08:00        09:00        10:00        11:00     

    

       12:00        13:00        14:00        15:00        16:00        17:00        18:00        19:00        20:00        21:00        22:00        23:00     

    

2015-05-30:

    

       00:00        01:00        02:00        03:00        04:00        05:00        06:00        07:00        08:00        09:00        10:00        11:00     

    

       12:00        13:00        14:00        15:00        16:00        17:00        18:00        19:00        20:00        21:00        22:00        23:00     

    

  
 

Le code back-end est le suivant :

<?php $data = $_POST[&#39;timetable&#39;];
file_put_contents(&#39;timetable.log&#39;, json_encode($data));
header(&#39;content-type:applicaiton/json;charset=utf8&#39;);echo json_encode(array(&#39;success&#39;=>true));?>


Par exemple, pour soumettre des données de réservation de 3 jours pour chaque utilisateur, des réservations pour toutes les périodes (tout sélectionner)
Les données de demande reçues par le backend sont les suivantes :

["2015-05-28 00:00:00","2015-05-28 01:00:00","2015-05-28 02:00:00","2015-05-28 03:00:00","2015-05-28 04:00:00","2015-05-28 05:00:00","2015-05-28 06:00:00","2015-05-28 07:00:00","2015-05-28 08:00:00","2015-05-28 09:00:00","2015-05-28 10:00:00","2015-05-28 11:00:00","2015-05-28 12:00:00","2015-05-28 13:00:00","2015-05-28 14:00:00","2015-05-28 15:00:00","2015-05-28 16:00:00","2015-05-28 17:00:00","2015-05-28 18:00:00","2015-05-28 19:00:00","2015-05-28 20:00:00","2015-05-28 21:00:00","2015-05-28 22:00:00","2015-05-28 23:00:00","2015-05-29 00:00:00","2015-05-29 01:00:00","2015-05-29 02:00:00","2015-05-29 03:00:00","2015-05-29 04:00:00","2015-05-29 05:00:00","2015-05-29 06:00:00","2015-05-29 07:00:00","2015-05-29 08:00:00","2015-05-29 09:00:00","2015-05-29 10:00:00","2015-05-29 11:00:00","2015-05-29 12:00:00","2015-05-29 13:00:00","2015-05-29 14:00:00","2015-05-29 15:00:00","2015-05-29 16:00:00","2015-05-29 17:00:00","2015-05-29 18:00:00","2015-05-29 19:00:00","2015-05-29 20:00:00","2015-05-29 21:00:00","2015-05-29 22:00:00","2015-05-29 23:00:00","2015-05-30 00:00:00","2015-05-30 01:00:00","2015-05-30 02:00:00","2015-05-30 03:00:00","2015-05-30 04:00:00","2015-05-30 05:00:00","2015-05-30 06:00:00","2015-05-30 07:00:00","2015-05-30 08:00:00","2015-05-30 09:00:00","2015-05-30 10:00:00","2015-05-30 11:00:00","2015-05-30 12:00:00","2015-05-30 13:00:00","2015-05-30 14:00:00","2015-05-30 15:00:00","2015-05-30 16:00:00","2015-05-30 17:00:00","2015-05-30 18:00:00","2015-05-30 19:00:00","2015-05-30 20:00:00","2015-05-30 21:00:00","2015-05-30 22:00:00","2015-05-30 23:00:00"]

Optimiser les appels des clients vers les interfaces serveur pour réduire la capacité des données de requête

Demander la longueur du contenu des données :2879

L'utilisation de cette méthode pour demander la capacité des données est relativement importante, ce qui affecte le temps de réponse.

Méthode d'amélioration 1 : Convertir l'heure au format DateTime en horodatage avant de soumettre

Le code front-end est modifié comme suit : Modifier le méthode javascript fsubmit

  <script type="text/javascript">
    function fsubmit(){
        var timetable = [];
        $("#myform input[type=checkbox]").each(function(){
            if(this.checked){                // 把时间转为时间戳
                var time = $(this).val();                var timestamp = Date.parse(new Date(time));
                timestamp = timestamp / 1000;

                timetable.push(timestamp);
            }
        });        if(timetable.length==0){
            alert(&#39;请选择预约时间&#39;);            return false;
        }

        $.post("http://localhost/server.php",{timetable:timetable}).done(function(data){
            if(data[&#39;success&#39;]==true){
                alert(&#39;提交成功&#39;);                
            }else{
                alert(&#39;提交失败&#39;);
            }
        });

    }  </script>

Les données de requête reçues par le backend sont les suivantes :

["1432742400","1432746000","1432749600","1432753200","1432756800","1432760400","1432764000","1432767600","1432771200","1432774800","1432778400","1432782000","1432785600","1432789200","1432792800","1432796400","1432800000","1432803600","1432807200","1432810800","1432814400","1432818000","1432821600","1432825200","1432828800","1432832400","1432836000","1432839600","1432843200","1432846800","1432850400","1432854000","1432857600","1432861200","1432864800","1432868400","1432872000","1432879200","1432882800","1432886400","1432890000","1432893600","1432897200","1432900800","1432904400","1432908000","1432911600","1432915200","1432918800","1432922400","1432926000","1432929600","1432933200","1432936800","1432940400","1432944000","1432947600","1432951200","1432954800","1432958400","1432962000","1432965600","1432969200","1432972800","1432976400","1432980000","1432983600","1432987200","1432990800","1432994400","1432998000"]

Optimiser les appels des clients vers les interfaces serveur pour réduire la capacité des données de requête

Contenu des données de requête -length:1916

Après l'avoir reçu, le backend peut convertir l'horodatage au format datetime et utiliser

Méthode d'amélioration 2 : Utilisez une variable entière de 32 bits, stockez chaque heure sous la forme d'un chiffre d'un entier de 32 bits

La relation correspondante entre le point et l'entier de 32 bits est
de droite à. gauche est 00:00, 01:00,02:00,03:00 et ainsi de suite, s'il y a une période horaire sélectionnée, ce sera 1, sinon ce sera 0

Par exemple : vous devez faire une réservation pour 10h00, 12h00 le 28/05/2016 ,14:00,16:00,18:00

 0   0    0   0   0   0   0    0   0  0  0  0  0  1  0  1  0  1  0  1  0  1  0  0  0  0  0  0  0  0  0  0
忽略 忽略 忽略 忽略 忽略 忽略 忽略 忽略 23 22 21 20 19 18 17 16 15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00

est exprimé en binaire 32 bits comme 1010101010000000000, soit décimal 349184 = 2 à la puissance 10 + 2 à la puissance 12 + 2 à la puissance 14 + 2 à la puissance 16 + 2 à la puissance 18
Le code du front-end est modifié comme suit : Modifier la méthode javascript fsubmit

  <script type="text/javascript">
    function fsubmit(){
        var timetable = [];        var tmp = {};
        $("#myform input[type=checkbox]").each(function(){
            if(this.checked){                // 拆分日期与时间
                var datetime = $(this).val();                var datetime = datetime.split(&#39; &#39;);                var day = datetime[0];                var time = parseInt(datetime[1].substring(0,2));                // 创建日期与时间数组
                if(typeof(tmp[day])==&#39;undefined&#39;){
                    tmp[day] = [];
                }
                tmp[day].push(time);
            }
        });        // 合拼数据,转换格式
        for(day in tmp){            // 根据数据集合,合拼,创建10进制数据
            var time = tmp[day];            var timeint = 0;            for(var i=0; i<time.length; i++){
                timeint += Math.pow(2,time[i]);
            }

            timetable.push(day+&#39; &#39;+timeint);
        }        if(timetable.length==0){
            alert(&#39;请选择预约时间&#39;);            return false;
        }

        $.post("http://localhost/server.php",{timetable:timetable}).done(function(data){
            if(data[&#39;success&#39;]==true){
                alert(&#39;提交成功&#39;);
            }else{
                alert(&#39;提交失败&#39;);
            }
        });

    }  </script>

Les données de requête reçues par le backend sont les suivantes :

["2015-05-28 16777215","2015-05-29 16777215","2015-05-30 16777215"]

Optimiser les appels des clients vers les interfaces serveur pour réduire la capacité des données de requête

Demander la longueur du contenu des données :107

En utilisant cette méthode, quel que soit le nombre les heures de réservation sont sélectionnées dans une journée, il n'y aura qu'un seul enregistrement, ce qui réduit considérablement la taille des données soumises.
La méthode principale de conversion du décimal en temps :
1. Convertissez le décimal en binaire et inversez
2. > avec une valeur de 1. 3. Le code

de sauvegarde de l'enregistrement est le suivant :

<?php$datetime = &#39;2015-05-28 1398016&#39;;list($day, $time) = explode(&#39; &#39;, $datetime);$bintime = decbin($time);$bintime = strrev($bintime);$result = array();for($i=0,$len=strlen($bintime); $i<$len; $i++){    if(substr($bintime, $i, 1)==1){        $result[] = $day.&#39; &#39;.str_pad($i, 2, &#39;0&#39;, STR_PAD_LEFT).&#39;:00:00&#39;;
    }
}
print_r($result);?>

Sortie :

Array(
    [0] => 2015-05-28 08:00:00
    [1] => 2015-05-28 10:00:00
    [2] => 2015-05-28 12:00:00
    [3] => 2015-05-28 14:00:00
    [4] => 2015-05-28 16:00:00
    [5] => 2015-05-28 18:00:00
    [6] => 2015-05-28 20:00:00)

Résumé : Cet article fournit une méthode qui peut convertir de grandes quantités de données en transmission de données de petite capacité, mais cela nécessite l'ajout d'opérations supplémentaires. Par conséquent, dans le développement réel, il est nécessaire de juger si l’algorithme d’échange de temps contre espace ou d’espace contre temps est adapté aux besoins réels.

Cet article explique comment optimiser le client pour appeler l'interface du serveur afin de réduire la capacité de données de la demande. Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois.

Recommandations associées :

mysql order by rand() méthode d'optimisation de l'efficacité

php Obtenez la date de début et la date de fin Toutes les dates entre

méthode php pour obtenir des combinaisons aléatoires à partir de nombres spécifiés

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:
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