При попытке отправить длинную строку (изображение в кодировке 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;
Мой вопрос: почему данные с внешнего сервера неполные, а данные, полученные с локального сервера, являются полными, и что я могу сделать, чтобы решить эту проблему.
Я нашел решение, проблема была в том, что в пути некоторых файлов были включены пробелы (я думаю, что это довольно плохой дизайн), из-за этого страница 404 кодировалась в base64, и таким образом были добавлены неверные данные. в моем локальном серверном приложении я не настроил страницу 404, поэтому она просто возвращала бы ноль, и у меня был запасной вариант для решения этой ситуации. Я заменил все пробелы на% 20, и ошибки были устранены.
Других решений пока нет …