Heim > Artikel > Backend-Entwicklung > Eine kurze Analyse, wie PHP die häufig verwendete Instant-Delivery-Funktion im App_php-Beispiel implementiert
Vorwort
Stellen Sie sich vor, wenn wir normalerweise auf WeChat Moments posten, werden N Bilder mit Text gepaart und sie werden blitzschnell und ohne jegliche Schlamperei verschickt. Das Erlebnis fühlt sich so cool an~.
Aber lassen Sie uns innehalten und technisch darüber nachdenken: Ist das möglich? Einige 2G-Netzwerke haben höchstens eine Geschwindigkeit von mehreren zehn Kilobyte. Unsere Bilder sind jeweils nur wenige Megabyte groß, und selbst wenn sie komprimiert sind, sind sie Hunderte von Kilobyte groß.
Wenn ich jetzt darüber nachdenke, ist es nicht ein bisschen seltsam~
Tatsächlich verwenden viele soziale Software (Weibo, WeChat) einen Instant-Messaging-Mechanismus. Es sendet es nicht wirklich zuerst und teilt Ihnen dann mit, dass es erfolgreich gesendet wurde, sondern teilt Ihnen direkt mit, dass es erfolgreich gesendet wurde, und lädt dann heimlich im Hintergrund hoch, was Sie gesendet haben, sodass wir häufig ein Phänomen feststellen, wenn die Netzwerkgeschwindigkeit beeinträchtigt ist Nicht gut, die neu gesendeten Momente waren zunächst normal, aber nach ein paar Minuten wurde uns mitgeteilt, dass der Versand fehlgeschlagen ist! Das ist sehr peinlich. Du hast am Anfang nichts gesagt, aber im kritischsten Moment hast du mir gesagt, dass du es nicht mehr kannst..
Lassen Sie sich nicht von der fortschrittlichen Technologie einschüchtern. Es sind nur ein paar kleine Tricks, aber es ist auch wirklich praktisch.
Erklären Sie zunächst einige Ausgangsbedingungen, bevor Sie über die Technologie sprechen.
1. An der Datenbanktabellenstruktur wurden einige spezielle Änderungen vorgenommen: Die Inhaltstabelle des Freundeskreises hat einen speziellen Feldstatus. Der Wert kann 1 oder 2 sein,
Ein Wert von 1 bedeutet, dass der Freundeskreis nicht veröffentlicht wurde. Ein Wert von 2 bedeutet, dass der Freundeskreis veröffentlicht wurde. (Schüler, die nicht verstehen, warum das so ist, können zuerst weiterlesen, ich werde es später erklären)
2. Die Funktion zum sofortigen Posten dieses Artikels bezieht sich auf die Verwendung, wenn Bilder vorhanden sind. Wenn Bilder vorhanden sind, ist das Hochladen von Bildern zu langsam. Wenn jedoch keine Bilder vorhanden sind, muss der Mechanismus zum sofortigen Posten verwendet werden Bilder und nur Text, es wird nicht zu groß sein. Da das Textübertragungsvolumen sehr gering ist, senden Sie es einfach gemäß dem normalen Prozess.
3. Der Code dieses Artikels basiert auf dem PhalApi-Framework und die Syntax ist relativ einfach. Studenten, die Erfahrung mit ORM-Operationen haben, sollten ihn verstehen
4. In diesem Artikel wird hauptsächlich die zweite Sendefunktion der APP erläutert. Diese Funktion wird auf der WEB-Seite nicht besonders benötigt, da das moderne Netzwerk ausreicht, damit unser PC viele, viele Bilder auf einmal senden kann (10 M/s, 20M/s)
Lassen Sie uns den gesamten Ausführungsprozess im Allgemeinen besprechen:
Der Client ruft die Veröffentlichungs-API auf und der Server veröffentlicht den Inhalt (publish.php). Wenn Bilder vorhanden sind, ruft der Client auch eine zusätzliche Upload-API auf (upload.php), wenn die Upload-API (upload.php) die Arbeit nicht abgeschlossen hat, teilt Ihnen der Client direkt mit, dass die Veröffentlichung erfolgreich war (tatsächlich ist der Upload derzeit noch nicht abgeschlossen, und es gibt einen Prozess dahinter, der Ihnen beim Hochladen dringend hilft), dann fügt der Client vorübergehend den von Ihnen gesendeten Text und die Bilder zusammen und zeigt sie Ihnen an (derzeit können nur Sie sie sehen, nicht andere in Ihrem Freundeskreis), und dann wartet er auf die Hochzuladende API (upload.php)/ Natürlich kann es beim Hochladen auch zu einer Zeitüberschreitung kommen (das Ergebnis ist normalerweise innerhalb einer Minute verfügbar, wenn es fehlschlägt). , es wird einen Fehler beim Senden melden. Innerhalb einer Minute nach dem Warten auf das Ergebnis wird Ihnen jedoch zunächst das Gefühl gegeben, dass Sie es gesendet haben, es sei denn, der Upload schlägt fehl.
Lassen Sie uns diesen Mechanismus also auf technischer Ebene analysieren:
Wenn wir oben rechts auf die Schaltfläche „Senden“ klicken, werden zwei Prozesse gleichzeitig gestartet. Einer davon soll Ihnen beim Hochladen des Textes helfen und Ihnen mitteilen, dass er erfolgreich gesendet wurde (
publish.php ) und der andere Vorgang besteht darin, die von Ihnen gesendeten Bilder heimlich hochzuladen (upload.php). Der spezifische Code lautet wie folgt:
Publish.php
<?php //正常获取数据(文本,图片,位置信息等) … Code … Code … //进行判断,如果有图片则为未发布(status为1),无图片则为立即发布(status为2) //如果有图片则通过返回标识符告诉客户端,让他赶紧去调用真实的上传逻辑upload.php,我们这只把最基本的文本上传好,再设置多一个status而已~ $status = ($pic_num > 0) ? 1 : 2; //拼接入库数据 $where_data = array( "status"=> $status) //数据入库 DI()->notorm-> friends ->insert($where_data); ?>
Status vorgenommen. Es gibt zwei Situationen: 1 (unveröffentlicht) und 2 (veröffentlicht). Was sollen wir also tun, wenn wir die Daten lesen (list.php). )?
Dann sieht die Anzeigeseite so aus:
Lists.php
<?php //code .. //获取文字信息 Code.. //获取图片信息 //(它在获取当前用户pic表内的f_id(即获取朋友圈图片),最关键的地方是where条件 $data= DI()->notorm->pic->select('f_id')->where("status > 1 OR (status = 1 && u_id = {$u_id})")->->fetchAll(); //code .. ?>
此处的where条件是秒发机制的最关键的地方:
status大于1(已发表)或者等于1(未发布),(tips:status在有图片的情况下默认值为1)但是属于当前用户发布的内容,都可以读出来,这就有一个很奇妙的现象,就是无论如何,我们自己发的朋友圈,自己永远是可以读出来的,但是其他人就不一定了(因为如果有图片的话,还需要去调用另外一个进程上传图片,然后在那个进程将status改为2)
那么还有最后一个关键点,就是负责上传图片的那个进程(upload.php),这个是真实上传图片的逻辑,
有几张图片,这么upload.php就会被调用几次
每次上传成功后将图片行的字段status改成2
upload.php
<?php //Code.. //把图片上传到服务器目录 //获取长传结果标识,更改状态 If(上传成功){ //将status改回2 $status_data = array("status" => 2); DI()->notorm->pic->select('u_id')->where('u_id, $u_id)-->update($status_data); }else{ Code… }
经过以上的几个操作(首先是publish.php,如果有图片上传的话则调用upload.php,展示的时候是list.php)。
不知道大家看出门道没有,和我们平常写的发布功能不同的是,上传upload.php功能被独立出来了,改装后的发布publish.php会用最快的速度将你的文本内容存进数据库,并且如果有图片内容的话,他会单独调用上传API upload.php。
最关键的是在显示的时候做了一些小技巧,让自己保证可以看到自己发的东西。
好了,以上就是本文的全部内容了,希望对大家学习PHP有所帮助,也请大家继续关注脚本之家。