Umstieg PHP5.2 auf PHP5.4: Unterschied zwischen den Versionen

Aus helpdesk
Wechseln zu: Navigation, Suche
(Was ändert sich im Programmcode beim Umstieg von PHP Version 5.2 nach 5.4?)
 
Zeile 33: Zeile 33:
 
  neu: htmlentities($text,NULL, "")
 
  neu: htmlentities($text,NULL, "")
 
</pre>
 
</pre>
 +
 +
* betroffen Quote-Symbole (" und ') die skriptseitig über htmlspecialchars() in Formularfelder (input, textarea, etc.) geschrieben werden. Der Effekt ist der gleiche wie bei den Umlauten (s.o.)
 +
<pre>
 +
alt: htmlspecialchars($text)
 +
neu: htmlspecialchars($text,ENT_QUOTES,"")
 +
</pre>
  
 
== Anwendungsbeispiele ==
 
== Anwendungsbeispiele ==

Aktuelle Version vom 9. April 2013, 13:29 Uhr

Was ändert sich im Programmcode beim Umstieg von PHP Version 5.2 nach 5.4?

'alter' Code / 'neuer' Code:

  • betroffen $HTTP_XXXX_VARS
 alt: $HTTP_GET_VARS['img']
 neu: $_GET['img']
 alt: $HTTP_POST_VARS['password']
 neu: $_POST['password']
  • betroffen SERVER-Variablen und Environment
 alt: $DOCUMENT_ROOT
 neu: $_SERVER['DOCUMENT_ROOT']
 alt: $PHP_SELF
 neu: $_SERVER['PHP_SELF']
 alt: $HOME
 neu: $_ENV['HOME']
  • betroffen Sessions
 alt: session_register('var')
      $var = Wert
 neu: $_SESSION['var'] = Wert
  • betroffen Umlaute mit der Funktion htmlspecialchars() und htmlentities(). Die neue PHP5.4er Version hat neue Standardencoding (vor PHP5.4 ISO-8859-1, seit PHP5.4 UTF-8)
 alt: htmlspecialchars($text)
 neu: htmlspecialchars($text,NULL, "")
 alt: htmlentities($text)
 neu: htmlentities($text,NULL, "")
  • betroffen Quote-Symbole (" und ') die skriptseitig über htmlspecialchars() in Formularfelder (input, textarea, etc.) geschrieben werden. Der Effekt ist der gleiche wie bei den Umlauten (s.o.)
alt: htmlspecialchars($text)
neu: htmlspecialchars($text,ENT_QUOTES,"")

Anwendungsbeispiele

alt: undefinierter index in array

      $do = $_GET['do'];
      if ($do == 'verify')
      [...]

neu: abfragen ob array-element existiert, ggf. initialisieren/definieren der Variable do

      if (!empty($_GET['do']))
                $do = $_GET['do'];
      else
                $do = "";
      if ($do == 'verify')
      [...] 

Debuggen

Sämtliche Fehler, Warnungen, Notizen und Hinweise auf deprecated (veraltete) Functions können mit Hilfe des Funktionsaufrufes

      error_reporting(E_ALL); 

am Anfang eines PHP-Programmes, hinter dem öffnenden PHP Start-Tag, angezeigt werden.

Usefull Links: