Как закодировать файл xls в base64?

Я кодирую файл xls в base64, используя php. Затем я отправляю его с помощью curl на свой сервер (используя API). Я расшифровываю его, но когда я загружаю файл, я получаю нечитаемый файл.

$xls = file_get_contents('/home/vacation/test.xls');

// Encode the image string data into base64
$data = base64_encode($xls);

Отправка файла с помощью curl

curl -X POST http://example.com/api/ -d 'data = {//here goes a json with encoded file}'

как вы храните его на стороне сервера? проблема ВОЗМОЖНО в нем. Кроме того, почему вы используете кодировку json и base64? вместо этого вы должны использовать multipart/form-data, и curl (через параметр -F, например curl -F data=@file http://example.com/api), и php (через $_FILES) имеют встроенную поддержку загрузки файлов с multipart/form-data, и вы также избегаете 33% накладных расходов base64

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

Ответы 1

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

-X POST примерно переводится как CURLOPT_POST=>1, а -d 'data = {//here goes a json with encoded file}' примерно переводится как CURLOPT_POSTFIELDS=>json_encode(array('data'=>'here goes encoded file')), поэтому

$ch = curl_init('http://example.com/api/');
curl_setopt_array($ch, array(
    CURLOPT_POST => 1,
    CURLOPT_POSTFIELDS => json_encode(array(
        'data' => base64_encode(file_get_contents('/home/vacation/test.xls'))
    ))
));
curl_exec($ch);
curl_close($ch);

.. но для загрузки двоичных файлов вы вообще не должны использовать json/base64, вы должны использовать multipart/form-data, кто бы ни разработал этот API, вероятно, не имел опыта в создании веб-API, использование json и base64 - дерьмовый дизайн решение, имхо. (худшая часть этого заключается в том, что он использует примерно на 33% больше пропускной способности, чем у multipart/form-data, но multipart также имеет встроенную поддержку от curl cli с параметром -F и встроенную поддержку от PHP в параметре $_FILES, и нативная поддержка от php-curl с классом CURLFile.также сложно сделать json&base64-реализацию где не обязательно весь файл сразу в памяти находиться для создания запроса на перенос)

Насколько я понимаю, они используют base64 и json, потому что вы можете отправлять файлы И файлы.

pepe_botika69 24.05.2019 09:21

@pepe_botika69, так что можно использовать multipart/form-data. здесь я отправляю 1 файл и 2 поля, смотрите: i.imgur.com/1Mduir8.png

hanshenrik 24.05.2019 11:10

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