208 похожих чатов

Приветствую. При попытке обновить запись в HL-инфоблоке выводится ошибка Cannot access offset

of type string on string (0)
Проблемный код:
$_id = (int)$_record['ID'];
$_data = [
"UF_ACTIVE" => 'N',
"UF_TIMESTAMP" => $_timestamp,
"UF_CHANGED" => $_datetime,
];
$_result = $entity_data_class::update($_id, $_data);

Кто-нибудь уже решал такую проблему?
Php 8.1, Bitrix 23.500.200

7 ответов

114 просмотров

Мало информации. Но скорее всего, в тп.

Владимир- Автор вопроса

Например, трейс

Владимир- Автор вопроса
Eugene Zhukov
Мало информации. Но скорее всего, в тп.

До обновления идёт запрос записей из ИБ. Если запись удалять (комментирую функцию обновления), то такой проблемы нет. $hlblock = Highloadblock\HighloadBlockTable::getById( $_hlIb )->fetch(); $entity = Highloadblock\HighloadBlockTable::compileEntity($hlblock); $entity_data_class = $entity->getDataClass(); $rsData = $entity_data_class::getList(array( 'select' => array('*'), 'order' => array('ID' => 'DESC'), // Всегда будет самая "свежая" запись 'filter' => array('UF_ACTIVE' => 'Y', 'UF_USER_ID' => $_userId), 'limit' => $_limit, )); if ( $rsData->getSelectedRowsCount() >= 1 ): while ( $_record = $rsData->Fetch() ): $_timestamp = time(); $_datetime = ConvertTimeStamp( $_timestamp, 'FULL' ); $_data = [ "UF_ACTIVE" => 'N', // "UF_TIMESTAMP" => $_timestamp, // "UF_CHANGED" => $_datetime, ]; $_id = (int)$_record['ID']; $hlblock = Highloadblock\HighloadBlockTable::getById( $_hlIb )->fetch(); $entity = Highloadblock\HighloadBlockTable::compileEntity($hlblock); $entity_data_class = $entity->getDataClass(); $_result = $entity_data_class::update($_id, $_data); // $_result = $entity_data_class::delete($_id); // $entity_data_class::update($_id, $_data); // echo('search6'); //if ( $_result->getId() > 0 ) // $result[$_result->getId()]++; // TODO: 12/2/20, 11:31 AM, vladimir. // Добавить обработку сбоя: перехват выброса исключения, // $_result->getError*, журналирование и т.п. // echo '<pre>' . print_r( $_result, 1 ) . "</pre>"; // Debug endwhile; endif;

Владимир- Автор вопроса
Eugene Zhukov
Например, трейс

Пожалуйста Cannot access offset of type string on string (0) /home/bitrix/ext_www/sitename.ru/local/php_interface/init.php:203 #0: OnAfterUpdate #1: call_user_func_array /home/bitrix/www/bitrix/modules/main/lib/eventmanager.php:444 #2: Bitrix\Main\EventManager->sendToEventHandler /home/bitrix/www/bitrix/modules/main/lib/eventmanager.php:380 #3: Bitrix\Main\EventManager->send /home/bitrix/www/bitrix/modules/main/lib/event.php:142 #4: Bitrix\Main\Event->send /home/bitrix/www/bitrix/modules/main/lib/orm/event.php:162 #5: Bitrix\Main\ORM\Event->send /home/bitrix/www/bitrix/modules/highloadblock/lib/datamanager.php:491 #6: Bitrix\Highloadblock\DataManager::callOnAfterUpdateEvent /home/bitrix/www/bitrix/modules/highloadblock/lib/datamanager.php:315 #7: Bitrix\Highloadblock\DataManager::update /home/bitrix/ext_www/sitename.ru/local/php_interface/include/functions.php:1772 #8: _deactivate /home/bitrix/ext_www/sitename.ru/local/php_interface/include/functions.php:1693 #9: _insert /home/bitrix/ext_www/sitename.ru/works/index.php:946

Владимир
Пожалуйста Cannot access offset of type string on...

И при чем тут битрикс? Валится кастомный обработчик в init.php, 203 строка. Скорее всего ждет массив, приходит строка.

Владимир- Автор вопроса
Eugene Zhukov
И при чем тут битрикс? Валится кастомный обработчи...

Для обновления записи в HL-инфоблоке передаётся массив, где 2 элемента - тип строка/инт, а третий - 'Bitrix\Main\Type\DateTime Object'. В кастомном обработчике этот массив обрабатывался в цикле, в результате 'обвал' на попытке считать объект как строку.

Похожие вопросы

Обсуждают сегодня

Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Чтобы перехватить все нажимания буков на форме, надо хук ставить? Пробовал на форме ОнКейДаун, оно ловит клаву если фокус не на компоненте с вводом текста
Serjone
15
лучше скажите, причём тут паскаль?
Alexey Kulakov
36
Всем привет! вывожу на общей стр дочерние ресурсыв каждом ресурсе галерея, и первая фотка должна выводиться на общей [!DocLister? &prepare=photo !]
Alekso
12
А можно вопрос? Мне сегодня сказали что у меня функция (которая просто заполняет массив значениями) не правильная void Full(double * arr, int n) { for (int i = 0; i < n; i...
† C E †
7
День добрый, подскажите пожалуйста, есть ли какой-то способ сказать ребару не компилировать определённое приложение? Всю доку их перечиатл ничего подобного не нашёл
Кирилл
14
Добрый вечер. Хочу чтобы у меня в классе поле было функцией, которая возвращает строку. Делаю так: interface ... TGetOutPath = function : String of object; ... protec...
Kirill Filippenok
12
Народ! Впервые клиенту пришло письмо от РКН, у вас, дескать, есть яндекс метрика, а нигде не написано, что вы ее юзаете. Никто не сталкивался?
Sasha Beep
10
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Здравствуйте, хочу сделать HelloWorld в консоли Дельфи, но функция API ничего не выводит, что я делаю не так? program Hello; {$APPTYPE CONSOLE} uses System.SysUtils, WinAPI.Wi...
Sergey Vinogradov
20
Карта сайта