Kohana PHP, ORM и MySQL BLOB

Я пытаюсь создать и получить BLOB-объект в таблице MySQL через библиотеку ORM Kohana.

Код выглядит примерно так:

$attachment = new Attachment_Model();
$attachment->name = $info['FileName'];
$attachment->size = strlen($info['Data']);
$attachment->data = $info['Data'];
$attachment->mime_type = $info['content-type'];
$attachment->save();

Я проверил, что данные на данный момент в порядке, выведя их в файл. Однако, когда я извлекаю данные, они оказываются поврежденными. Мне удалось сузить это немного больше - я использовал инструмент запросов MySQL для извлечения данных, хранящихся в базе данных, и я могу проверить, что данные в базе данных повреждены, поэтому проблема должна быть в INSERT .

Кроме того, введенные файлы не всегда повреждены - файлы меньшего размера (например, изображения), как правило, подходят.

У кого-нибудь есть идеи?

Стоит ли изучать 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 и хотите разрабатывать...
3
0
1 930
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Дикое предположение, но: вероятно, потому что слой модели коханы вставляет все данные как символьные, а не двоичные, что вызовет проблемы при сохранении / извлечении объектов BLOB.

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

Оказывается, в этом случае я использовал тип данных BLOB.

Тип данных BLOB усекает данные до 65535 символов (без вывода сообщений об ошибке!)

Я увеличил его до MEDIUMBLOB (максимальная длина которого составляет 16777215 символов), и, похоже, он работает нормально!

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