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
Мало информации. Но скорее всего, в тп.
А какую еще надо бы?
Например, трейс
До обновления идёт запрос записей из ИБ. Если запись удалять (комментирую функцию обновления), то такой проблемы нет. $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;
Пожалуйста 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
И при чем тут битрикс? Валится кастомный обработчик в init.php, 203 строка. Скорее всего ждет массив, приходит строка.
Для обновления записи в HL-инфоблоке передаётся массив, где 2 элемента - тип строка/инт, а третий - 'Bitrix\Main\Type\DateTime Object'. В кастомном обработчике этот массив обрабатывался в цикле, в результате 'обвал' на попытке считать объект как строку.
Обсуждают сегодня