Heim >Backend-Entwicklung >PHP-Tutorial >10 Wissenspunkte, über die PHP-Anfänger verwirrt sind

10 Wissenspunkte, über die PHP-Anfänger verwirrt sind

伊谢尔伦
伊谢尔伦Original
2016-12-01 11:12:01934Durchsuche

【1】Variablen können nicht zwischen Seiten übertragen werden. Automatische globale Get-, Post- und Session-Variablen sind in der neuesten PHP-Version deaktiviert. Um die übermittelten Variablen von der vorherigen Seite abzurufen, verwenden Sie also $_GET['foo']. ,$_POST['foo'],$_SESSION['foo'] zu bekommen. Natürlich können Sie auch die automatischen globalen Variablen so ändern, dass sie aktiviert sind (php.ini wird in register_globals = On geändert). Aus Kompatibilitätsgründen ist es besser, sich mit der neuen Schreibmethode vertraut zu machen.

Hinweis: Superglobale Variablen in PHP
Ab PHP 4.2.0 ist der Standardwert von register_globals deaktiviert. Auf diese Weise können viele frühere Variablen direkt verwendet werden, z. B. $PHP_SELF oder Sie Auf bestimmte SESSION-Variablen kann nicht in der Form „$Variablenname“ zugegriffen werden. Dies bringt möglicherweise viele Änderungen mit sich, trägt jedoch zur Verbesserung der Sicherheit bei. Um auf diese Variablen zuzugreifen, müssen Sie superglobale PHP-Variablen wie folgt verwenden:
$_SERVER
Variablen werden vom Webserver festgelegt oder direkt mit der Ausführungsumgebung des aktuellen Skripts verknüpft. Ähnlich dem alten $HTTP_SERVER_VARS-Array. Das vorherige $PHP_SELF entspricht $_SERVER['PHP_SELF']. Sie können phpinfo verwenden, um Ihre $_SERVER-Variable anzuzeigen.
$_GET
Variablen, die über die HTTP-GET-Methode an das Skript übermittelt werden. Ähnlich dem alten $HTTP_GET_VARS-Array.
$_POST
Variablen, die über die HTTP-POST-Methode an das Skript übermittelt werden. Ähnlich dem alten $HTTP_POST_VARS-Array.
$_COOKIE
Eine Variable, die über die HTTP-Cookies-Methode an das Skript übermittelt wird. Ähnlich dem alten $HTTP_COOKIE_VARS-Array.
$_SESSION
Die aktuell für die Skriptsitzung registrierte Variable. Ähnlich dem alten $HTTP_SESSION_VARS-Array.
$_FILES
Variablen, die per HTTP-POST-Datei-Upload an das Skript übermittelt werden. Ähnlich dem alten $HTTP_POST_FILES-Array.
$_ENV
Die Variable, die von der Ausführungsumgebung an das Skript übermittelt wird. Ähnlich dem alten $HTTP_ENV_VARS-Array.

============================================= === ====================
Für die Variable $_FILES: (Das Dateidomänenfeld ist „myfile“)
$_FILES[' myfile'][' name']
Der ursprüngliche Name der Client-Maschinendatei (einschließlich Pfad).
$_FILES['myfile']['type']
Der MIME-Typ der Datei, der erfordert, dass der Browser diese Informationen unterstützt, z. B. „image/gif“.
$_FILES['myfile']['size']
Die Größe der hochgeladenen Datei in Bytes.
$_FILES['myfile']['tmp_name']
Der temporäre Dateiname (einschließlich Pfad), der nach dem Hochladen der Datei auf dem Server gespeichert wird.
$_FILES['myfile']['error']
Fehlercode im Zusammenhang mit dem Datei-Upload. ['error'] wurde in der PHP 4.2.0-Version hinzugefügt.
Wenn register_globals in php.ini aktiviert ist, entspricht $myfile_name $_FILES['myfile']['name'], $myfile_type entspricht $_FILES['myfile']['type' ]wait .

【2】Sitzung unter Win32 funktioniert nicht richtig
php.ini default session.save_path = /tmp
Dies ist offensichtlich eine Konfiguration unter Linux. PHP kann unter Win32 keine Sitzungsdateien lesen und schreiben. Die Sitzung kann nicht verwendet werden. Ändern Sie sie einfach in einen absoluten Pfad, z. B. session.save_path = c:windowstemp.

【3】Fehlermeldungen anzeigen
Wenn display_errors von php.ini = On und error_reporting = E_ALL, werden alle Fehler und Eingabeaufforderungen während des Debuggens zur Fehlerbehebung angezeigt Sie verwenden In der Vergangenheit handelte es sich bei den meisten Fehlermeldungen beim PHP-Schreiben um undefinierte Variablen. Wenn eine Variable aufgerufen wird, wird vor der Zuweisung eine Eingabeaufforderung angezeigt. Die Lösung besteht darin, sie zu erkennen oder zu blockieren. Wenn beispielsweise $foo angezeigt wird, können Sie if(isset($foo)) echo $foo oder echo @$foo verwenden

【4】Header bereits gesendet
Dieser Fehler tritt normalerweise auf, wenn Sie HEADER verwenden. Dies kann mehrere Gründe haben: 1. Sie haben PRING oder ECHO verwendet, bevor Sie HEADER verwenden. 2. Davor befindet sich eine Leerzeile Ihrer aktuellen Datei 3. Möglicherweise haben Sie eine Datei INCLUDEd, dieser Fehler tritt auch auf, wenn am Ende der Datei oder der Ausgabe eine Leerzeile steht.

【5】Keine Änderung nach Änderung von php.ini
Starten Sie den Webserver wie IIS, Apache usw. neu, dann werden die neuesten Einstellungen angewendet.

【6】Manchmal funktioniert die SQL-Anweisung nicht und der Datenbankvorgang schlägt fehl. Der einfachste Weg zum Debuggen besteht darin, die SQL-Anweisung zu wiederholen, um zu sehen, ob der Wert der Variablen abgerufen werden kann.

【7】Der Unterschied zwischen include und require
Es gibt keinen großen Unterschied zwischen den beiden. Wenn die einzuschließende Datei nicht vorhanden ist, werden Sie aufgefordert, die folgende Anweisung auszuführen: require löst einen schwerwiegenden Fehler aus und wird beendet. Dem Test zufolge werden sie unter der Win32-Plattform zuerst eingebunden und dann ausgeführt. Daher ist es am besten, keine include- oder require-Anweisungen in den eingebundenen Dateien zu haben, da dies zu Verzeichnisverwirrungen führen würde. Möglicherweise ist die Situation unter *nux anders, ich habe es noch nicht getestet. Wenn Sie nicht möchten, dass eine Datei mehrfach eingebunden wird, können Sie include_once oder require_once## verwenden, um Dokumentdaten zu lesen und zu schreiben:
function r($file_name) {
$filenum=@fopen($file_name ,"r");
@flock($filenum,LOCK_SH);
$file_data=@fread($filenum,filesize($file_name));
@fclose($filenum);
return $file_data;
}
function w($file_name,$data,$method="w"){
$filenum=@fopen($file_name,$method);
flock($ filenum,LOCK_EX);
$file_data=fwrite($filenum,$data);
fclose($filenum);
return $file_data;
}

【8】Der Unterschied zwischen isset() und empty()
Beide werden zum Testen von Variablen verwendet, aber isset() testet, ob einer Variablen ein Wert zugewiesen wurde, während empty() eine Variable testet, der ein Wert zugewiesen wurde Ob es leer ist. Wenn in PHP auf eine Variable verwiesen wird, ohne dass ihr ein Wert zugewiesen wurde, ist dies zulässig, es wird jedoch ein Hinweis angezeigt. Wenn einer Variablen ein Nullwert zugewiesen wird, $foo="" oder $foo=0 oder $foo=false, dann gibt empty($foo) true zurück und isset($foo) gibt ebenfalls true zurück, was bedeutet, dass ein Nullwert zugewiesen wird keine Variable abmelden. Um die Registrierung einer Variablen aufzuheben, verwenden Sie unset($foo) oder $foo=NULL.

[9] Die MySQL-Abfrageanweisung enthält Schlüsselwörter
Wenn PHP MySQL abfragt, enthält der MySQL-Tabellenname oder Spaltenname manchmal Schlüsselwörter, und zu diesem Zeitpunkt tritt ein Fehler in der Abfrage auf. Wenn der Tabellenname beispielsweise order ist, tritt während der Abfrage ein Fehler auf. Die einfache Möglichkeit besteht darin, „[über der Tabulatortaste]“ zum Tabellennamen oder Spaltennamen in der SQL-Anweisung hinzuzufügen, um ihn zu unterscheiden, z. B. „select * from“. „Bestellung“.

【10】Die Methode zum gleichzeitigen Hochladen mehrerer Dateien über das HTTP-Protokoll
hat zwei Ideen, die zwei Implementierungen derselben Methode sind. Die spezifischen Verfahren müssen von Ihnen selbst entworfen werden
1. Richten Sie mehrere Dateieingabefelder im Formular ein und benennen Sie sie wie folgt mit Arrays:
< 🎜 >< input name="usefile[]" type="file" >
< input name="usefile[]" type="file" >
< ] " type="file" >
< /form >
Führen Sie auf diese Weise den folgenden Test auf der Serverseite aus
echo " < pre > $_FILES);
echo " < /pre > ";

2. Richten Sie mehrere Dateieingabefelder im Formular ein, jedoch mit unterschiedlichen Namen, wie folgt:
< ="" method="post" >
< input name="usefile_a" type="file" >
< input name="usefile_b" type="file" >
< ; input name="usefile_c" type="file" >
< /form >
Führen Sie den gleichen Test auf der Serverseite durch:
echo " < pre > ";
print_r($_FILES);
echo " < /pre > ";

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn