Запятая (,), указанная в имени файла, заставляет процессор curl не отправлять запрос - PullRequest
0 голосов
/ 25 апреля 2020

У меня есть класс процессора Curl, который используется для отправки запросов и получения ответа в виде простой строки.

Он работал как чудо, однако недавно я столкнулся с проблемой. Проблема связана с отправкой многокомпонентных данных. Итак, если в многочастном теле задана запятая (возможно, другой специальный символ), она даже не отправляет никакого запроса.

Вот что я имею в виду (основной метод ниже)

public static String buildCurlProcessBuilderExecuteAndGetResponse(String httpMethod, String URL, List<String> headers, List<String> body, boolean includeResponseHeaders) throws IOException 
{
        List<String> finalCommands = new ArrayList<String>();

        finalCommands.add("/usr/local/bin/curl");
        finalCommands.add("-s");
        finalCommands.add("-k");

        if (includeResponseHeaders) 
        {
            finalCommands.add("-i");
        }

        finalCommands.add("-X");
        finalCommands.add(httpMethod);

        finalCommands.add(URL);

        if (headers != null) 
        {
            finalCommands.addAll(headers);
        }

        if (body != null) 
        {
            finalCommands.addAll(body);
        }

        ProcessBuilder pb = new ProcessBuilder(finalCommands);
        pb.redirectErrorStream(true);       
        Process p = pb.start();
        return getResponseAsString(p.getInputStream());
}

Я добавляю составное тело следующим образом:

public static List<String> addMultipartBodyToCurlRequest(Map<String, String> mapOfheadersToAdd) 
{
        Iterator<Entry<String, String>> multipartBodyIt = mapOfheadersToAdd.entrySet().iterator();
        List<String> bodyCommand = new ArrayList<String>();

        while (multipartBodyIt.hasNext())
        {       
            Map.Entry pair = (Map.Entry) multipartBodyIt.next();

            bodyCommand.add(CURL_MULTIPART_BODY_IDENTIFIER); // "-F";
            bodyCommand.add((String) pair.getKey() + "=" + (String) pair.getValue());
        }

        return bodyCommand;
}

Я добавляю в тело следующие свойства:

generatedBody.put("entityId", entityId);
generatedBody.put("SystemFolderID", systemFolderId);
generatedBody.put("resumableTotalSize", fileSize);
generatedBody.put("resumableFilename", fileName);
generatedBody.put("resumableRelativePath", fileName);
generatedBody.put("resumableIdentifier", fileUUID);
generatedBody.put("entityName", entityName);
generatedBody.put("resumableType", resumableType);
generatedBody.put("resumableTotalChunks", totalChunksSize);

А также

generatedBody.put("resumableChunkNumber", String.valueOf(i + 1));
generatedBody.put("resumableChunkSize", String.valueOf(chunkByteArray.length));
generatedBody.put("resumableCurrentChunkSize", String.valueOf(chunkByteArray.length));
generatedBody.put("file", "@" + currentChunk.getAbsolutePath() + ";" + "filename=" + fileName);

Затем я вызываю метод :

List<String> fileBody = CURLRequestProcessor.addMultipartBodyToCurlRequest(generatedBody);

И, наконец, позвоните

CURLRequestProcessor.buildCurlProcessBuilderExecuteAndGetResponse("POST", finalURL, generatedHeaders, fileBody, false)

Но я ничего не печатаю ... Кажется, одна простая запятая в имени файла все испортила ... Используется в частях resumableFilename, resumableRelativePath и file.

Без запятой в названии все работает. Есть ли способ убежать или сделать что-нибудь?

Кстати, он работает на Ubuntu.

Почти забыл, ПОЖАЛУЙСТА, НЕ ЗАПРОСИТЕ МНЕ, ПОЧЕМУ Я ИСПОЛЬЗУЮ CURL НАД любым другим HTTP-клиент . Я должен из-за TLS

Большое спасибо заранее!

Ответы [ 2 ]

0 голосов
/ 30 апреля 2020

Решение оказалось простым, но своеобразным.

Проблема была связана с этой строкой:

generatedBody.put("file", "@" + currentChunk.getAbsolutePath() + ";" + "filename=" + fileName);

Я изменил ее на:

generatedBody.put("file", "@" + currentChunk.getAbsolutePath());

Поскольку я отправляю имя файла в 2 дополнительных частях тела, называемых resumableFilename и resumableRelativePath, указание filename является излишним. В последнем запятая запутывается, в то время как с этими двумя частями запятая не имеет значения

0 голосов
/ 25 апреля 2020

Заголовки HTTP поддерживают строки в кавычках, содержащие специальные символы. Попробуйте поместить значения в кавычки.

generatedBody.put("resumableRelativePath", "\"" + fileName + "\"");

Если имя вашего файла содержит символ ", вы можете экранировать его с помощью одной обратной косой черты sh в строке в кавычках.

...