It is also possible ( in 5.6.0alpha ) to typehint the ...-operator
function foo (stdclass ... $inbound) {
var_dump($inbound);
}
// ok:
foo( (object)['foo' => 'bar'], (object)['bar' => 'foo'] );
// fails:
foo( 1, 2, 3, 4 );
Es ist nun möglich einen skalaren Ausdruck mit numerischen oder String-Literalen und/oder Konstanten in Kontexten zu verwenden, in denen PHP bisher einen statischen Wert erwartete, beispielsweise Deklarationen von Konstanten und Eigenschaften und Standardwerte von Funktionsparametern.
<?php
const ONE = 1;
const TWO = ONE * 2;
class C {
const THREE = TWO + 1;
const ONE_THIRD = ONE / self::THREE;
const SENTENCE = 'Der Wert von THREE ist '.self::THREE;
public function f($a = ONE + self::THREE) {
return $a;
}
}
echo (new C)->f()."\n";
echo C::SENTENCE;
?>
Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
4 Der Wert von THREE ist 3
Es ist nun auch möglich, ein konstantes Array mit dem
Schlüsselwort const
zu definieren:
<?php
const ARR = ['a', 'b'];
echo ARR[0];
?>
Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
a
...
Variadische Funktionen
können nun mit dem Operator ...
implementiert werden,
anstatt func_get_args() zu verwenden.
<?php
function f($req, $opt = null, ...$params) {
// $params ist ein Array welches die übrigen Parameter enthält.
printf('$req: %d; $opt: %d; Anzahl Parameter: %d'."\n",
$req, $opt, count($params));
}
f(1);
f(1, 2);
f(1, 2, 3);
f(1, 2, 3, 4);
f(1, 2, 3, 4, 5);
?>
Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
$req: 1; $opt: 0; Anzahl Parameter: 0 $req: 1; $opt: 2; Anzahl Parameter: 0 $req: 1; $opt: 2; Anzahl Parameter: 1 $req: 1; $opt: 2; Anzahl Parameter: 2 $req: 1; $opt: 2; Anzahl Parameter: 3
...
Arrays und
Traversable-Objekte können in eine Liste
von Parametern entpackt werden, indem der ...
Operator
verwendet wird. Dies ist in anderen Sprachen, wie beispielsweise Ruby,
auch als Splat-Operator bekannt.
<?php
function add($a, $b, $c) {
return $a + $b + $c;
}
$operators = [2, 3];
echo add(1, ...$operators);
?>
Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
6
**
Der rechtsassoziative Operator **
zum Potenzieren
wurde gemeinsam mit dem abkürzenden Zuweisungsoperator
**=
hinzugefügt.
<?php
printf("2 ** 3 == %d\n", 2 ** 3);
printf("2 ** 3 ** 2 == %d\n", 2 ** 3 ** 2);
$a = 2;
$a **= 3;
printf("a == %d\n", $a);
?>
Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
2 ** 3 == 8 2 ** 3 ** 2 == 512 a == 8
use function
und use const
Der Operator
use
wurde um das Importieren von Funktionen und Konstanten zusätzlich zu
Klassen erweitert. Dies kann jeweils entsprechend durch die Konstrukte
use function
bzw. use const
erreicht werden.
<?php
namespace Name\Space {
const FOO = 42;
function f() { echo __FUNCTION__."\n"; }
}
namespace {
use const Name\Space\FOO;
use function Name\Space\f;
echo FOO."\n";
f();
}
?>
Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
42 Name\Space\f
PHP enthält nun einen interaktiven Debugger namens phpdbg, welcher als SAPI-Modul umgesetzt wurde. Weitere Informationen findet man in der phpdbg-Dokumentation.
default_charset wird nun als Standardzeichenkodierung für die Funktionen htmlentities(), html_entity_decode() und htmlspecialchars() herangezogen. Falls die (nun missbilligten) Einstellungen für die Zeichenkodierung von iconv und mbstring gesetzt sind, haben diese Vorrang gegenüber default_charset für die iconv beziehungsweise mbstring Funktionen.
Die Standardeinstellung hierfür ist UTF-8
.
php://input
ist wiederverwendbar
php://input
kann nun so oft wie nötig geöffnet und ausgelesen werden. Diese Änderung hat
auch zu einer erheblichen Reduktion im Speicherverbrauch bei der Verarbeitung
von POST-Daten geführt.
Es werden nun auch Dateien mit einer Größe von mehr als zwei Gigabyte angenommen.
GMP-Objekte unterstützen nun Operatorüberladung und das Casten zu skalaren Typen. Dies erlaubt besser lesbaren Code bei Verwendung von GMP:
<?php
$a = gmp_init(42);
$b = gmp_init(17);
if (version_compare(PHP_VERSION, '5.6', '<')) {
echo gmp_intval(gmp_add($a, $b)), PHP_EOL;
echo gmp_intval(gmp_add($a, 17)), PHP_EOL;
echo gmp_intval(gmp_add(42, $b)), PHP_EOL;
} else {
echo $a + $b, PHP_EOL;
echo $a + 17, PHP_EOL;
echo 42 + $b, PHP_EOL;
}
?>
Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
59 59 59
Die Funktion hash_equals() wurde hinzugefügt, welche zwei Zeichenketten in konstanter Zeit vergleicht. Dies sollte verwendet werden, um Rechenzeitangriffe zu verhindern, beispielsweise wenn crypt()-Passworthashes geprüft werden (unter der Annahme, dass password_hash() und password_verify() nicht verwendet werden können, welche gegen Rechenzeitangriffe nicht anfällig sind).
<?php
$expected = crypt('12345', '$2a$07$benutzeeinenlangenstringalssalt$');
$correct = crypt('12345', '$2a$07$benutzeeinenlangenstringalssalt$');
$incorrect = crypt('1234', '$2a$07$benutzeeinenlangenstringalssalt$');
var_dump(hash_equals($expected, $correct));
var_dump(hash_equals($expected, $incorrect));
?>
Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
bool(true) bool(false)
__debugInfo()
Die magische Methode __debugInfo() wurde hinzugefügt, welche es Objekten erlaubt, die Eigenschaften und Werte zu bestimmen, welche bei Verwendung von var_dump() ausgegeben werden.
<?php
class C {
private $prop;
public function __construct($val) {
$this->prop = $val;
}
public function __debugInfo() {
return [
'propSquared' => $this->prop ** 2,
];
}
}
var_dump(new C(42));
?>
Das oben gezeigte Beispiel erzeugt folgende Ausgabe:
object(C)#1 (1) { ["propSquared"]=> int(1764) }
Der Hashalgorithmus gost-crypto
wurde hinzugefügt.
Dieser implementiert die GOST-Hash-Funktion unter Verwendung der
CryptoPro S-box Tabellen wie in
» RFC 4357, Abschnitt 11.2
spezifiziert.
Eine große Zahl an Verbesserungen an der SSL/TLS-Unterstützung wurden in PHP 5.6 vorgenommen. Dies umfasst die standardmäßige Aktivierung von Peer-Verifikation, Unterstützung von Zertifikat-Fingerabdrucksprüfung, Verhinderung von TLS-Renegotiation-Attacken und viele neue SSL Kontextoptionen, welche eine detailliertere Kontrolle über Protokoll- und Verifikationseinstellungen bei Verwendung von verschlüsselten Streams erlauben.
Diese Änderungen werden im Abschnitt OpenSSL Änderungen in PHP 5.6.x dieser Migrationsanleitung detaillierter beschrieben.
Die Extension pgsql unterstützt
nun asynchrone Verbindungen und Abfragen, womit nicht blockierendes
Verhalten bei der Interaktion mit PostgreSQL-Datenbanken ermöglicht
wird. Asynchrone Verbindungen können mittels der Konstante
PGSQL_CONNECT_ASYNC
aufgebaut werden, und die
neuen Funktionen pg_connect_poll(),
pg_socket(), pg_consume_input()
und pg_flush() behandeln asynchrone Verbindungen
und Abfragen.
It is also possible ( in 5.6.0alpha ) to typehint the ...-operator
function foo (stdclass ... $inbound) {
var_dump($inbound);
}
// ok:
foo( (object)['foo' => 'bar'], (object)['bar' => 'foo'] );
// fails:
foo( 1, 2, 3, 4 );
Remember, that
($a ** $b) ** $c === $a ** ($b * $c)
Thats why exponent operator** is RIGHT associative.
Note the order of operations in that exponentiation operator, as it was opposite of what my first expectation was:
<?php
// what I had expected,
// evaluating left to right,
// since no parens were used to guide the order of operations
2 ** 3 ** 2 == 64; // (2 ** 3) ** 2 = 8 ** 2 = 64
// the given example,
// which appears to evaluate right to left
2 ** 3 ** 2 == 512; // 2 ** (3 ** 2) = 2 ** 9 = 512
?>
Having 2 ** 3 ** 2 = 512 is actually that is the exact correct behavior for a right-associative operator just as specified in the "**" documentation.
<?php
function array_zip(...$arrays) {
return array_merge(...array_map(NULL, ...$arrays));
}
$a = array(1, 4, 7);
$b = array(2, 5, 8);
$c = array(3, 6, 9);
var_dump(implode(', ', array_zip($a, $b, $c)));
// Output
string(25) "1, 2, 3, 4, 5, 6, 7, 8, 9"
You can create a self-documented, named argument workaround in PHP 5.6-7 with ... operator:
<?php
htmlspecialchars($string, ...array_values([
'flags' => ENT_COMPAT | ENT_HTML401,
'encoding' => 'UTF-8',
'double_encode' => false,
]))
?>