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 ответов

122 просмотра

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

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

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

Владимир- Автор вопроса
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'. В кастомном обработчике этот массив обрабатывался в цикле, в результате 'обвал' на попытке считать объект как строку.

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта