ПОЧЕМУ ЭТО ПРОИСХОДИТ?
Со временем PHP стал более ориентированным на безопасность языком. Настройки, которые раньше были отключены по умолчанию, теперь включены по умолчанию. Прекрасным примером этого является E_STRICT
, который стал включенным по умолчанию с PHP 5.4.0 .
Кроме того, согласно документации PHP, по умолчанию, E_NOTICE
отключен в php.ini. Документы PHP рекомендуют включить его для целей отладки . Однако, когда я загружаю PHP из репозитория Ubuntu - и из стека Windows BitNami - я вижу что-то еще.
; Common Values:
; E_ALL (Show all errors, warnings and notices including coding standards.)
; E_ALL & ~E_NOTICE (Show all errors, except for notices)
; E_ALL & ~E_NOTICE & ~E_STRICT (Show all errors, except for notices and coding standards warnings.)
; E_COMPILE_ERROR|E_RECOVERABLE_ERROR|E_ERROR|E_CORE_ERROR (Show only errors)
; Default Value: E_ALL & ~E_NOTICE & ~E_STRICT & ~E_DEPRECATED
; Development Value: E_ALL
; Production Value: E_ALL & ~E_DEPRECATED & ~E_STRICT
; http://php.net/error-reporting
error_reporting = E_ALL & ~E_DEPRECATED & ~E_STRICT
Обратите внимание, что на самом деле error_reporting
по умолчанию установлено на производственное значение, а не на значение по умолчанию. Это несколько сбивает с толку и не документировано за пределами php.ini, поэтому я не проверил это в других дистрибутивах.
Однако, чтобы ответить на ваш вопрос, эта ошибка появляется сейчас, когда она не появлялась раньше, потому что:
Вы установили PHP, и новые настройки по умолчанию немного плохо документированы, но не исключают E_NOTICE
.
E_NOTICE
предупреждения, такие как неопределенные переменные и неопределенные индексы, на самом деле помогают сделать ваш код чище и безопаснее. Я могу вам сказать, что несколько лет назад включение E_NOTICE
заставило меня объявить мои переменные. Это значительно облегчило изучение языка C, если не объявлять переменные, это намного больше неприятностей.
Что я могу сделать об этом?
Выключите E_NOTICE
, скопировав «Значение по умолчанию» E_ALL & ~E_NOTICE & ~E_STRICT & ~E_DEPRECATED
и заменив его на то, что в данный момент не комментируется после знака равенства в error_reporting =
. Перезапустите Apache или PHP, если используете CGI или FPM. Убедитесь, что вы редактируете «правильный» php.ini. Правильный вариант будет Apache, если вы используете PHP с Apache, fpm или php-fpm, если вы используете PHP-FPM, cgi, если вы используете PHP-CGI и т. Д. Это не рекомендуемый метод, но если у вас есть устаревший код, который собирается быть чрезвычайно трудным для редактирования, тогда это может быть вашей лучшей ставкой.
Отключите E_NOTICE
на уровне файлов или папок. Это может быть предпочтительнее, если у вас есть какой-то устаревший код, но в противном случае вы хотите сделать все «правильно». Для этого вам следует проконсультироваться с Apache2, Nginx или любым другим вашим сервером. В Apache вы должны использовать php_value
внутри <Directory>
.
Перепишите свой код, чтобы он стал чище. Если вам нужно сделать это при переходе в производственную среду или вы не хотите, чтобы кто-то видел ваши ошибки, убедитесь, что вы отключили отображение ошибок и только регистрируете ваши ошибки (см. display_errors
и log_errors
в php.ini и настройках вашего сервера).
Чтобы расширить вариант 3: это идеальный вариант. Если вы можете пойти по этому пути, вы должны. Если вы изначально не идете по этому пути, рассмотрите возможность его перемещения в конечном итоге, протестировав свой код в среде разработки. Пока вы в этом, избавьтесь от ~E_STRICT
и ~E_DEPRECATED
, чтобы увидеть, что может пойти не так в будущем. Вы увидите много незнакомых ошибок, но это предотвратит возникновение неприятных проблем при необходимости обновления PHP в будущем.
ЧТО ОЗНАЧАЮТ ОШИБКИ?
Undefined variable: my_variable_name
- это происходит, когда переменная не была определена перед использованием. Когда скрипт PHP выполняется, он просто принимает нулевое значение. Однако в каком сценарии вам нужно проверить переменную, прежде чем она будет определена? В конечном счете, это аргумент в пользу «небрежного кода». Как разработчик, я могу сказать, что мне нравится, когда я вижу проект с открытым исходным кодом, в котором переменные определены настолько высоко, насколько это возможно. Это упрощает определение переменных, которые появятся в будущем, и облегчает чтение / изучение кода.
function foo()
{
$my_variable_name = '';
//....
if ($my_variable_name) {
// perform some logic
}
}
Undefined index: my_index
- Это происходит, когда вы пытаетесь получить доступ к значению в массиве, а оно не существует. Чтобы предотвратить эту ошибку, выполните условную проверку.
// verbose way - generally better
if (isset($my_array['my_index'])) {
echo "My index value is: " . $my_array['my_index'];
}
// non-verbose ternary example - I use this sometimes for small rules.
$my_index_val = isset($my_array['my_index'])?$my_array['my_index']:'(undefined)';
echo "My index value is: " . $my_index_val;
Другой вариант - объявить пустой массив в верхней части вашей функции. Это не всегда возможно.
$my_array = array(
'my_index' => ''
);
//...
$my_array['my_index'] = 'new string';
(дополнительный совет)
- Когда я столкнулся с этими и другими проблемами, я использовал NetBeans IDE (бесплатно), и он дал мне множество предупреждений и уведомлений,Некоторые из них предлагают очень полезные советы.Это не является обязательным требованием, и я больше не использую интегрированные среды разработки, за исключением крупных проектов.В наши дни я больше
vim
человек:).