Я пытаюсь показать текст с FTP-сервера в textView.Сам код не показывает ошибок, но когда я запускаю приложение, textView становится пустым.FTP-сервер не требует входа в систему.И да, я добавил интернет-разрешение в файл манифеста.Кроме того, я реализовал Apache IOutilis для преобразования inputStream в String.
Я думаю, что код не завершен, но я понятия не имею, что мне нужно добавить, чтобы заставить его работать.
Вот чтоУ меня на данный момент:
public class MainActivity extends AppCompatActivity {
public TextView textOutput;
public String string;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
textOutput = findViewById(R.id.text_view);
FTPdownload ftPdownload = new FTPdownload();
ftPdownload.execute();
}
private class FTPdownload extends AsyncTask<Void, Void, Void> {
@Override
protected Void doInBackground(Void... params) {
FTPClient ftpClient = new FTPClient();
try {
ftpClient.connect("ftp.mysite.com");
ftpClient.enterLocalPassiveMode();
ftpClient.changeWorkingDirectory("working_directory");
InputStream inStream = ftpClient.retrieveFileStream("file.txt");
string = IOUtils.toString(inStream, UTF_8);
ftpClient.disconnect();
} catch (IOException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
@Override
protected void onPostExecute(Void Str) {
textOutput.setText(string);
}
}
}
Заранее спасибо.
(я знаю об утечке памяти в классе AsynTask, но я знаю, как это исправить)
РЕДАКТИРОВАТЬ: отладочный вывод
W/System.err: java.lang.NullPointerException
at java.io.Reader.<init>(Reader.java:78)
at java.io.InputStreamReader.<init>(InputStreamReader.java:113)
at org.apache.commons.io.IOUtils.copy(IOUtils.java:2440)
at org.apache.commons.io.IOUtils.toString(IOUtils.java:1084)
at com.example.ftp.MainActivity$FTPdownload.doInBackground(MainActivity.java:45)
at com.example.ftp.MainActivity$FTPdownload.doInBackground(MainActivity.java:34)
at android.os.AsyncTask$2.call(AsyncTask.java:333)
at java.util.concurrent.FutureTask.run(FutureTask.java:266)
at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:245)
W/System.err: at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1162)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:636)
at java.lang.Thread.run(Thread.java:764)