Данные неполные при переносе из PHP в Java

При попытке отправить длинную строку (изображение в кодировке Base64) из php в java передается только часть данных. Когда я тестировал приложение на моем локальном apache-сервере, строка была отправлена ​​полностью, и приложение работало правильно. Но когда я перенес код на внешний сервер, только часть данных была получена на Java. Когда я вывожу данные в браузер, длинная строка отображается правильно.

Это код, который я использовал для отправки данных:

//get the data from mysql result
while($row = mysqli_fetch_assoc($result))
{
// get the fotopath
$fotoRow = mysqli_fetch_array ( $fotoResult, MYSQL_NUM );
$foto = $fotoRow[0];

//replace backslashes
$fotoFormatted = $foto; //str_replace($backslash, $slash, $foto);

//get the picture data
$im = file_get_contents("http://www.mywebsite.com" . $fotoFormatted, true);

//encode the picture data
$imdata = base64_encode($im);

//add the encoded string to the data array
$row ['foto'] = $imdata;
$output[] = $row;
}

//output the data as a json array
print(json_encode($output))

Это код, который я использовал для получения данных:

//get the url to the script to connect with
String link = "http://mywebsite/script.php";

//get the data to send to the script
String data = URLEncoder.encode("userid", "UTF-8") + "="+ URLEncoder.encode(userid, "UTF-8");

//make a new HttpURLConnection
URL url = new URL(link);
HttpURLConnection conn = (HttpURLConnection)url.openConnection();
conn.setDoOutput(true);

//make a new OutputStreamWriter with the HttpURLConnection
OutputStreamWriter wr = new OutputStreamWriter(
conn.getOutputStream());

//write the data and flush the remaining data
wr.write(data);
wr.flush();

//make a new BufferedReader with the given connection
BufferedReader reader = new BufferedReader(new InputStreamReader(
conn.getInputStream()));

//define variables
JSONArray jsonArray = null;
String line = null;

//read the data from the server
while ((line = reader.readLine()) != null) {
jsonArray = new JSONArray(line);
}

//disconnect the connection
conn.disconnect();

//return the data for further use
return jsonArray;

Мой вопрос: почему данные с внешнего сервера неполные, а данные, полученные с локального сервера, являются полными, и что я могу сделать, чтобы решить эту проблему.

0

Решение

Я нашел решение, проблема была в том, что в пути некоторых файлов были включены пробелы (я думаю, что это довольно плохой дизайн), из-за этого страница 404 кодировалась в base64, и таким образом были добавлены неверные данные. в моем локальном серверном приложении я не настроил страницу 404, поэтому она просто возвращала бы ноль, и у меня был запасной вариант для решения этой ситуации. Я заменил все пробелы на% 20, и ошибки были устранены.

0

Другие решения

Других решений пока нет …

По вопросам рекламы ammmcru@yandex.ru
Adblock
detector