Это не возможно, потому что это создает угрозу безопасности. Люди используют довольно реальную информацию для своей структуры папок, и доступ к именам папок сам по себе представляет собой непосредственный риск. Как описано здесь:
Получить путь загрузки браузера с помощью javascript
Большинство ОС обычно имеют значение по умолчанию для места загрузки, и это то, что пользователь решает через Браузер, который они используют. Не сайт.
Это хорошо документированное поведение PHP. См. предупреждение на странице foreach php.net
Warning
Ссылка на $ value , а последний элемент массива остается даже после цикла foreach . Рекомендуется уничтожить его unset ().
blockquote>$a = array('a', 'b', 'c', 'd'); foreach ($a as &$v) { } unset($v); foreach ($a as $v) { } print_r($a);
EDIT
Попытайтесь пошаговое руководство к тому, что на самом деле происходит здесь
$a = array('a', 'b', 'c', 'd'); foreach ($a as &$v) { } // 1st iteration $v is a reference to $a[0] ('a') foreach ($a as &$v) { } // 2nd iteration $v is a reference to $a[1] ('b') foreach ($a as &$v) { } // 3rd iteration $v is a reference to $a[2] ('c') foreach ($a as &$v) { } // 4th iteration $v is a reference to $a[3] ('d') // At the end of the foreach loop, // $v is still a reference to $a[3] ('d') foreach ($a as $v) { } // 1st iteration $v (still a reference to $a[3]) // is set to a value of $a[0] ('a'). // Because it is a reference to $a[3], // it sets $a[3] to 'a'. foreach ($a as $v) { } // 2nd iteration $v (still a reference to $a[3]) // is set to a value of $a[1] ('b'). // Because it is a reference to $a[3], // it sets $a[3] to 'b'. foreach ($a as $v) { } // 3rd iteration $v (still a reference to $a[3]) // is set to a value of $a[2] ('c'). // Because it is a reference to $a[3], // it sets $a[3] to 'c'. foreach ($a as $v) { } // 4th iteration $v (still a reference to $a[3]) // is set to a value of $a[3] ('c' since // the last iteration). // Because it is a reference to $a[3], // it sets $a[3] to 'c'.
Первый цикл foreach не производит никаких изменений в массиве, как и ожидалось. Тем не менее, это заставляет $v
присваивать ссылку на каждый из элементов $a
, так что к моменту окончания первого цикла $v
является, по сути, ссылкой на $a[2]
.
Как только начинается второй цикл, $v
теперь назначается значение каждого элемента. Однако $v
уже ссылается на $a[2];
, поэтому любое присвоенное ему значение будет автоматически скопировано в последний элемент массива!
Таким образом, во время первой итерации $a[2]
будет становятся нулевыми, затем одно, а затем снова, будучи эффективно скопированы на себя. Чтобы решить эту проблему, вы всегда должны отключать переменные, которые вы используете в своих циклах foreach by-reference, или, еще лучше, избегать использования прежнего вообще.
unset($v);
, почему$v
недоступен за пределами foreach? : о – nawfal 20 November 2015 в 14:15