#Прямая загрузка файла
POST /v1/storage/objects/upload
Загружает файл до 10 МБ одним запросом в формате multipart/form-data — сервер принимает файл и возвращает готовый объект хранилища.
#Поля запроса (body)
Тело запроса должно быть в формате multipart/form-data.
| Параметр | Тип | Обяз. | По умолч. | Описание |
|---|---|---|---|---|
file |
file | да | — | Бинарный файл размером не более 10 МБ; MIME-тип определяется из заголовка Content-Type части формы; если заголовок отсутствует, используется application/octet-stream |
key |
string | да | — | Логический ключ объекта: от 1 до 1024 символов, допустимы a-z, A-Z, 0-9, ., _, /, -; не начинать с / или ., не содержать .. |
visibility |
string | нет | PRIVATE |
Видимость объекта: PRIVATE или PUBLIC |
#Примеры
#curl — личный ключ
curl -X POST https://vibecode.bitrix24.tech/v1/storage/objects/upload \
-H "X-Api-Key: YOUR_API_KEY" \
-F "file=@avatar.png;type=image/png" \
-F "key=users/42/avatar.png" \
-F "visibility=PRIVATE"
#curl — OAuth-приложение
curl -X POST https://vibecode.bitrix24.tech/v1/storage/objects/upload \
-H "X-Api-Key: YOUR_APP_KEY" \
-H "Authorization: Bearer USER_SESSION_TOKEN" \
-F "file=@avatar.png;type=image/png" \
-F "key=users/42/avatar.png" \
-F "visibility=PRIVATE"
#JavaScript — личный ключ
const formData = new FormData()
formData.append('file', fileInput.files[0])
formData.append('key', 'users/42/avatar.png')
formData.append('visibility', 'PRIVATE')
const res = await fetch('https://vibecode.bitrix24.tech/v1/storage/objects/upload', {
method: 'POST',
headers: {
'X-Api-Key': 'YOUR_API_KEY',
},
body: formData,
})
if (!res.ok) {
const { error } = await res.json()
console.error(error.code, error.message)
return
}
const { object } = await res.json()
console.log('Object ID:', object.id)
#JavaScript — OAuth-приложение
const formData = new FormData()
formData.append('file', fileInput.files[0])
formData.append('key', 'users/42/avatar.png')
formData.append('visibility', 'PRIVATE')
const res = await fetch('https://vibecode.bitrix24.tech/v1/storage/objects/upload', {
method: 'POST',
headers: {
'X-Api-Key': 'YOUR_APP_KEY',
'Authorization': 'Bearer USER_SESSION_TOKEN',
},
body: formData,
})
const { object } = await res.json()
#Поля ответа
| Поле | Тип | Описание |
|---|---|---|
object.id |
string | Идентификатор объекта |
object.key |
string | Логический ключ объекта |
object.contentType |
string | MIME-тип файла |
object.sizeBytes |
string | Размер файла в байтах (строка) |
object.sha256 |
string | SHA-256 хеш файла или null |
object.visibility |
string | Видимость: PRIVATE или PUBLIC |
object.uploadStatus |
string | Статус загрузки: COMPLETED |
object.createdAt |
string | Дата создания (ISO 8601) |
object.deletedAt |
string | Дата удаления или null |
#Пример ответа
{
"object": {
"id": "cmpf9b1gp003omr0zkc0qjojn",
"key": "users/42/avatar.png",
"contentType": "image/png",
"sizeBytes": "20480",
"sha256": null,
"visibility": "PRIVATE",
"uploadStatus": "COMPLETED",
"createdAt": "2026-05-21T08:56:32.809Z",
"deletedAt": null
}
}
#Пример ответа при ошибке
415 — для PUBLIC-объектов передан MIME-тип, недопустимый из соображений межсайтового выполнения скриптов:
{
"success": false,
"error": {
"code": "STORAGE_FORBIDDEN_CONTENT_TYPE",
"message": "Content-Type text/html is not allowed for PUBLIC objects (XSS-prone)"
}
}
#Ошибки
| HTTP | Код | Описание |
|---|---|---|
| 403 | STORAGE_SCOPE_REQUIRED |
API-ключу не хватает скоупа vibe:storage |
| 401 | STORAGE_NO_AUTH_CONTEXT |
Запрос выполнен без авторизации |
| 400 | STORAGE_FILE_REQUIRED |
Не передано поле file |
| 400 | STORAGE_KEY_REQUIRED |
Не передано поле key |
| 400 | STORAGE_INVALID_KEY |
Значение key нарушает правила формата |
| 400 | STORAGE_INVALID_VISIBILITY |
Недопустимое значение visibility |
| 400 | STORAGE_MULTIPART_PARSE_FAILED |
Не удалось разобрать тело запроса как multipart/form-data |
| 413 | STORAGE_UPLOAD_TOO_LARGE |
Файл превышает 10 МБ — используйте предподписанный URL |
| 415 | STORAGE_FORBIDDEN_CONTENT_TYPE |
Для PUBLIC-объектов запрещены типы text/html, application/javascript, application/x-javascript, image/svg+xml |
| 402 | BILLING_INSUFFICIENT |
Недостаточно средств на балансе |
| 507 | STORAGE_QUOTA_EXCEEDED |
Исчерпана квота хранилища |
| 503 | STORAGE_FEATURE_DISABLED |
Хранилище отключено для портала |
| 502 | STORAGE_BUCKET_ERROR |
Ошибка при взаимодействии с хранилищем |
Полный список общих ошибок API — Ошибки.
#Известные особенности
Файлы крупнее 10 МБ. Для файлов от 10 МБ до 5 ГБ используйте предподписанный URL (Путь B). Для файлов крупнее 5 ГБ — составную загрузку (Путь C).
Проверка типа для PUBLIC-объектов. Проверка выполняется по заявленному Content-Type части формы до записи файла — при нарушении запрос отклоняется без обращения к хранилищу.