Dieser Artikel führt hauptsächlich in ein tiefgreifendes Verständnis des Ausführungszyklus von PHP-Prinzipien ein und analysiert kurz die relevanten Prinzipien des PHP-Programms von der Bearbeitung über die lexikalische Analyse, die Syntaxanalyse bis hin zur Interpretation und Ausführung. Freunde in Not können sich darauf beziehen
Der Ausführungszyklus von PHP, vom ersten PHP-Skript, das wir geschrieben haben –> bis zum endgültigen Skript, das ausgeführt wird –> kann dieser Prozess tatsächlich in die folgenden Phasen unterteilt werden:
Zuerst ruft Zend Engine (ZE) den lexikalischen Analysator auf (generiert von Lex, die Quelldatei befindet sich in Zend/zend_lingual_sanner.l), entfernt Leerzeichen und Kommentare aus der PHP-Quelldatei, die wir ausführen möchten, und teilt es nacheinander in Token auf.
Dann leitet ZE das erhaltene Token an den Syntaxanalysator weiter (generiert von yacc, die Quelldatei befindet sich in Zend/zend_sprache_parser.y) und generiert Opcodes nacheinander. Die Opcodes liegen im Allgemeinen in der Form vor op-Array. Es ist die Zwischensprache für die PHP-Ausführung.
Schließlich ruft ZE zend_executor auf, um das Op-Array auszuführen und das Ergebnis auszugeben. (Das heißt, konvertieren Sie die Quelldatei in Maschinensprache und führen Sie sie dann auf einer virtuellen Maschine aus.)
ZE ist eine virtuelle Maschine. Gerade aufgrund ihrer Existenz können wir PHP-Skripte schreiben, ohne dass dies erforderlich ist Berücksichtigen Sie die Art des Betriebssystems, auf dem Sie arbeiten. Aus diesem Grund ist PHP portierbar. ZE ist ein CISC (Complex Instruction Processor), der 150 Anweisungen unterstützt (spezifische Anweisungen finden Sie in Zend/zend_vm_opcodes.h), einschließlich des einfachsten ZEND_ECHO (echo) bis zum komplexen ZEND_INCLUDE_OR_EVAL (include, require), Alle Das von uns geschriebene PHP wird schließlich in eine Folge dieser 150 Anweisungen (Op-Code) verarbeitet und schließlich ausgeführt .
PHP ist eine Skriptsprache, das heißt, der vom Benutzer geschriebene PHP-Code wird schließlich vom PHP-Interpreter interpretiert und ausgeführt. Der gesamte geschriebene PHP-Code wird in die virtuelle PHP-Maschine übersetzt ZE virtuelle Anweisungen (OPCODES) zur Ausführung.
In was wird unser PHP-Skript letztendlich „übersetzt“? Mit anderen Worten: Wie sieht der Operationscode aus? Opcode ist eine Zwischensprache , die aus PHP-Skripten kompiliert wurde.
Es gibt bereits ein solches Modul in PECL, das das von Derick Rethans entwickelte VLD-Modul (Vulcan Logic Dissassembler) verwendet. Sie müssen dieses Modul nur herunterladen und in PHP laden, und Sie können das Ergebnis der Skriptübersetzung durch einfache Einstellungen erhalten.
Installation und Anwendung des VLD-Moduls:
[root@localhost software]# tar zxvf vld-0.9.1.tgz.gz [root@localhost vld-0.9.1]# /usr/local/php/bin/phpize [root@localhost vld-0.9.1]# ./configure --with-php-config=/usr/local/php/bin/php-config [root@localhost vld-0.9.1]# make install //不需要make
Bearbeiten Sie die php.ini-Datei und aktivieren Sie die vld-Erweiterung.
Beispiel:
Erstellen Sie eine Datei, z. B.: hello.php
<?php echo 'hello, world.'; ?>
Ausführung:
[root@localhost html]# /usr/local/php/bin/php -dvld.active=1 hello.php Branch analysis from position: 0 Return found filename: /var/www/html/hello.php function name: (null) number of ops: 3 compiled vars: none line # op fetch ext return operands ------------------------------------------------------------------------------- 2 0 ECHO 'hello%2C+world.' 4 1 RETURN 1 2* ZEND_HANDLE_EXCEPTION hello, world.
Anderes ansehen:
[root@localhost html]# vi vld.php <?php $i = "This is a string"; //I am comments echo $i. ' that has been echoed on screen'; ?>
Ausführen:
[root@localhost html]# /usr/local/php/bin/php -dvld.active=1 vld.php Branch analysis from position: 0 Return found filename: /var/www/html/vld.php function name: (null) number of ops: 5 compiled vars: !0 = $i line # op fetch ext return operands ------------------------------------------------------------------------------- 3 0 ASSIGN !0, 'This+is+a+string' 7 1 CONCAT ~1 !0, '+that+has+been+echoed+on+screen' 2 ECHO ~1 10 3 RETURN 1 4* ZEND_HANDLE_EXCEPTION This is a string that has been echoed on screen
Hinweis: ZEND_HANDLE_EXCEPTION ist die 149. Anweisung in Zend/zend_vm_opcodes.h
kompilierte Variablen: !0 = $i Hier ist der Variablenname „i“ Die Variable liegt bei !0 (*zval).
#0 Weisen Sie den String „this+is+a+string“ zu !0 zu
#1 String-Verbindung
#2 Anzeige
Diese Zwischencodes werden von Zend VM verwendet (Zend Virtuelle Maschine) wird direkt ausgeführt. Die eigentlich für die Ausführung verantwortliche Funktion ist: zend_execute (zend_execute.h).
Zusammenfassung: Das Obige ist der gesamte Inhalt dieses Artikels, ich hoffe, dass er für das Studium aller hilfreich sein wird.
Verwandte Empfehlungen:
So verwenden Sie PHP, um die regelmäßige Erfassung von URLs in Seiten zu implementieren
Identitätskartenüberprüfung basierend auf Berechnungsmethode für die PHP-Codeüberprüfung
Das obige ist der detaillierte Inhalt vonBeispielanalyse des PHP-Prinzipausführungszyklus. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Die Absolute -Sitzungs -Zeitlimit startet zum Zeitpunkt der Erstellung der Sitzung, während eine Zeitlimit in der Leerlaufsitzung zum Zeitpunkt der No -Operation des Benutzers beginnt. Das Absolute -Sitzungs -Zeitlimit ist für Szenarien geeignet, in denen eine strenge Kontrolle des Sitzungslebenszyklus erforderlich ist, z. B. finanzielle Anwendungen. Das Timeout der Leerlaufsitzung eignet sich für Anwendungen, die die Benutzer für lange Zeit aktiv halten, z. B. soziale Medien.

Der Serversitzungsausfall kann durch Befolgen der Schritte gelöst werden: 1. Überprüfen Sie die Serverkonfiguration, um sicherzustellen, dass die Sitzung korrekt festgelegt wird. 2. Überprüfen Sie die Client -Cookies, bestätigen Sie, dass der Browser es unterstützt und korrekt senden. 3. Überprüfen Sie die Speicherdienste wie Redis, um sicherzustellen, dass sie normal arbeiten. 4. Überprüfen Sie den Anwendungscode, um die korrekte Sitzungslogik sicherzustellen. Durch diese Schritte können Konversationsprobleme effektiv diagnostiziert und repariert werden und die Benutzererfahrung verbessert werden.

Session_Start () iscrucialinphPFormAnagingUSSERSIONS.1) ItinitiatesanewSessionifnoneExists, 2) Wiederaufnahmen und 3) setaSessionCookieforContinuityAcrossRequests, aktivierende Anwendungen wie

Das Festlegen des HTTPonly -Flags ist für Sitzungscookies von entscheidender Bedeutung, da es effektiv verhindern und die Informationen zur Benutzersitzung schützen kann. Insbesondere 1) Das Httponly -Flag verhindert, dass JavaScript auf Cookies zugreift, 2) Das Flag kann durch SetCookies eingestellt werden und in PHP und Flasche 3), obwohl es nicht von allen Angriffen von allen Angriffen verhindert werden kann, Teil der Gesamtsicherheitsrichtlinie sein sollte.

PhpSsionSsionSolvetheProblemofMaintainingStateAcrossmultipehttprequestsBoringDataontheserverandassociatingitittprequests.1) Sie starteten die Stundeataserver-Seite, typischerweise infileSordatabasen, undusaSasionIdinacookookookotenData

PHPSSIONS CANSTORESTRINGEN, ZUGNALTEN, ARRAYS, ANDOBjekte.1.

TostartaphpSession, useSession_start () atthescript'Sbeginning.1) PlaCEITBEFOREANYOUTPUTTOTHESESSIONSCOOKIE.2) useSsionsforuserDatalikeloginStatusOrShopingCarts

Die Sitzung der Sitzung bezieht sich auf die Generierung einer neuen Sitzungs -ID und die Ungültigmachung der alten ID, wenn der Benutzer sensible Vorgänge bei festgelegten Sitzungsangriffen ausführt. Die Implementierungsschritte umfassen: 1. Erkennen sensibler Vorgänge, 2. Erstellen neuer Sitzungs-ID, 3..


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

SublimeText3 Englische Version
Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

Sicherer Prüfungsbrowser
Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Herunterladen der Mac-Version des Atom-Editors
Der beliebteste Open-Source-Editor

VSCode Windows 64-Bit-Download
Ein kostenloser und leistungsstarker IDE-Editor von Microsoft
