Счетная проблема для PHP 7.2

У меня есть клиент, который годами полагался на плагин WP, от которого автор отказался несколько лет назад. Я смог внести некоторые исправления, чтобы заставить его работать с обновлением до PHP 7.2, но это меня озадачивает. Чем больше я исследую это, тем меньше я понимаю, как это исправить.

Предупреждение ниже:

Warning: count(): Parameter must be an array or an object that implements Countable in /app/public/wp-content/plugins/ozh-admin-drop-down-menu/inc/core.php on line 311 (first line below is 311)

if (!count($wp_ozh_adminmenu)) {
    $wp_ozh_adminmenu = (array)get_option('ozh_adminmenu');
    unset($wp_ozh_adminmenu[0]);
}

Является ли $wp_ozh_adminmenu массивом? Вы можете убедиться в этом?

Satish Saini 13.03.2019 17:02

и какова ценность $wp_ozh_adminmenu? Я предполагаю, что это строка. как насчет теста типа... if (!is_array($wp_ozh_adminmenu) || count($wp_ozh_adminmenu) === 0)

kuh-chan 13.03.2019 17:02

Не уверен, что понял, но просто завернул приведенный выше код в: if (!is_array($wp_ozh_adminmenu) || count($wp_ozh_adminmenu) === 0) { } Это не помогло.

Ray 13.03.2019 17:10
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
3
440
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

До PHP 7.2 при передаче немассива в count() он возвращал 1.
Теперь, как вы можете видеть в критические изменения, count() выдает предупреждение, когда вы даете ему не массив.

Простой обходной путь — проверить, является ли это массивом, прежде чем использовать его. Это может потребовать немного больше проверок, если вы хотите, например, разрешить массивы и строки.

<?php
if (!is_array($wp_ozh_adminmenu) || !count($wp_ozh_adminmenu)) {
    $wp_ozh_adminmenu = (array)get_option('ozh_adminmenu');
    unset($wp_ozh_adminmenu[0]);
}

Это исправило это. Может потребоваться мне немного больше исследований, чтобы понять, как/почему. Спасибо огромное!

Ray 13.03.2019 17:17

@Ray Исследования должны в основном касаться плагина, какие типы переменных он предоставляет вашей функции. Он может использовать несколько типов (например, массив или строку), и слабая типизация PHP позволяет ему это делать. С критическим изменением PHP 7.2 вам нужно немного адаптироваться. Если вы используете только is_array() и больше не разрешаете какой-либо другой тип, вы можете столкнуться с некоторыми проблемами в будущем, когда плагин попытается использовать вместо этого строку.

AnthonyB 13.03.2019 17:22

Другие вопросы по теме