mfromh
Goto Top

PHP Sourcecode incl. Code aus includes ausgeben?

include()- / require()-Statements durch deren Code ersetzen

Hallo Forum,

kann ich mir PHP-Code so anzeigen lassen, dass statt include() oder require() der Sourcecode angezeigt wird, der an dieser Stelle inkludiert wird? M.a.W. möchte ich die vom Precompiler zusammengesetzte Datei ausgeben, bevor sie durch den Compiler interpretiert wird.

Kennt jemand von Euch einen Weg?

Danke im voraus.

--
BFN
MFromH

Content-ID: 145791

Url: https://administrator.de/forum/php-sourcecode-incl-code-aus-includes-ausgeben-145791.html

Ausgedruckt am: 23.01.2025 um 02:01 Uhr

maretz
maretz 28.06.2010 um 14:22:01 Uhr
Goto Top
Moin,

das wird so nicht gehen - da PHP ne Script-Sprache ist die nicht durch nen (Pre-)Compiler sondern nur durch einen Interpreter läuft...

Da wäre mir höchstens der manuelle Weg bekannt... aber ganz ehrlich: Alles andere wäre auch Sinnfrei. Denn du hast ja immer nen paar (unsichtbare) Includes - nämlich deine PHP.ini die ausgewertet wird usw. (sonst wüsste dein Script ja nicht worauf es basiert). Und dann kommt da noch der Teil vom Webserver zu der das ganze PHP erstmal lädt (ohne das wüsste dein Webserver ja nicht was er z.B. mit dem Befehl "phpinfo();" anfangen soll...)
dog
dog 28.06.2010 um 14:28:06 Uhr
Goto Top
readfile() face-wink

Nein, so etwas gibt es nicht.
Das tiefste an das man aus PHP selbst rankommt ist __halt_compiler()

Vielleicht reicht dir aber schon ein Xdebug oder APD und das Setzen von Breakpoints und Überwachen mit gdb?

Oder inclued http://www.php.net/manual/de/intro.inclued.php ?
mfromh
mfromh 28.06.2010 um 16:32:03 Uhr
Goto Top
Danke für Eure Antworten.

Mich wundert eigentlich, dass mein Wunsch so exotisch ist, denn die Fragestellung, an welcher Stelle welche Variable / Function definiert bzw. verändert wird, ist ja bei einem PHP mit einigen incudes() doch gar nicht mal so leicht zu beantworten. Und letztlich kann ja auch ein entsprechendes Utility nicht sooo schwer zu coden sein ...

--
BFN
Michael
Arano
Arano 29.06.2010 um 00:22:26 Uhr
Goto Top
Nabend

Entsprechende Funktionen gibt es doch:
Damit sollte es möglich sein es in Erfahrung zu bringen

~Arano


EDIT:
Ähm ja.... hätte richtig lesen sollen, da helfen die ja auch nicht... sorry !
dog
dog 29.06.2010 um 00:44:49 Uhr
Goto Top
Wie gesagt, für sowas setzt man Breakpoints und überwacht die Ausführung mit einem Debugger
maretz
maretz 30.06.2010 um 00:02:35 Uhr
Goto Top
Moin,

naja, die frage ist: Warum sollte man das tun? Was bringt es mir das ich z.B. beim Include ITX.php dann erstmal zig Zeilen Code rausgeballert bekomme die mich gar nicht intressieren?

Was intressiert dich denn beim Debuggen deines Codes? Normal ja nur DEINE Variablen und der Zustand DEINES Programmes. Und nicht alles was du so ggf. inkludiert hast. Und den Zustand deines Programmes kannst du dir ja relativ simpel anzeigen lassen...

Nur mal zum Verständnis: Nehmen wir an du würdest ein Programm bauen welches den Code an der Stelle komplett einbindet.

In deinem Code steht
include itx.php
-> wird ersetzt durch den Code der in der itx.php steht. Soweit so gut.
Leider findest du in der itx.php dann sowas wie
require class.db.inc
require localFunctions.inc
require sonderfunktion.php

ok - also rein mit dem ganzen kram.
In der sonderfunktion.php findest du aber wieder ein
require class.db.inc
-> da man hier die DB-Funktionen in einer Klasse ausgelagert hat (nur mal angenommen!).

Na - merkst du wie lang der Code jetzt werden würde (denn die class.db.inc könnte ja ggf. 1000ende Zeilen enthalten - du willst aber in der sonderfunktionen.php nur ganz bestimmte funktionen davon nutzen!). Das wäre schonmal kontraproduktiv -> du hast keine Chance mehr den Code zu lesen...

Noch schlimmer wird es wenn du im Bereich Objektorientierung bist. Hier hast du z.B. eine Klasse "Auto" (das übliche halt). Du hast jetzt ein Programm welches dir die Anzahl der Türen zurückgibt - enthält logischerweise ein "include auto.inc". Ein anderer Programmteil gibt dir zurück wieviele Reifen das Auto hat - somit enthält auch der Teil ein "include auto.inc". Innerhalb der Auto.inc hättest du aber z.B. noch eine DB-Funktion - also wird hier schonmal die "db.class.inc" immer inkludiert... Du hättest also ein relativ simples Programm in kurzer Zeit extrem aufgepustet wenn du dir statt des include immer den Programm-Text reinlädst. Und ein Debuggen wäre nicht mehr möglich -> du hättest ja immer den kompletten Text statt des Includes. Aber was dein Programmteil "Anzahl der Türen" mit dem Programmcode zur Rückgabe der Reifenanzahl soll kannst du vermutlich nicht sagen - trotzdem würde der auch in dem Programmteil stehen und eher verwirren...

Also -> hat nen guten Grund das man das include so belässt wie es ist... ;)
mfromh
mfromh 30.06.2010 um 06:50:00 Uhr
Goto Top
OK, Ihr habt mich überzeugt face-wink

Danke.

--
BFN
Michael