Jsch рм нить синхро на андроид
Я работаю на sftp с Android. я использую JSch
установить канал между сервером и устройством, но у меня проблема:
Сначала пользователь должен выбрать список файлов для загрузки и для каждого файла intentService
создан для загрузки файла. Затем я делаю проверку md5, чтобы узнать, в порядке ли загрузка, и, наконец, если целостность в порядке, мне нужно удалить файл с сервера.
Основная проблема в том, что у меня ошибка: SftpException 4:
без описания, я думаю, что служба закрывается, когда я пытаюсь удалить файл с сервера, поэтому канал закрыт и файл не может быть найден.
У меня есть другая активность, отслеживающая все загрузки + глобальная прогрессия. Но я не могу удалить файл в этом, потому что Сеть на MainThread
... Так что я думаю, что я могу создать SftpChannel
в отдельном потоке и отдайте его деятельности. Но как я могу это сделать? я знаю это BroadcastIntents
не может отправить эти типы данных...
Итак, чтобы возобновить:
DownloadSFTPService => IntentService : open the SftpChannel
и скачать файл, отправить данные в RunningDownloadsActivity для прогрессии.
RunningDownloadsActivity => ListActivity : Monitor all the downloads + global receiving via BrodcastIntent updates from DownloadSftpService.
DownloadSftpService:
protected void onHandleIntent(Intent intent) {
//initializations
//Création de la session avec le serveur
JSch jsch = new JSch();
Session session = null;
try {
session = jsch.getSession(loginFtp, ipServer, GlobalEnum.DOWNLOAD.PORT);
if(session == null)
{
Log.e("SSHError","Impossible d'instancier la session");
}
else
{
//Configuration de la connexion par mot de passe plutot que certificat
java.util.Properties config = new java.util.Properties();
config.put("StrictHostKeyChecking", "no");
config.put("PreferredAuthentifications", "password");
session.setConfig(config);
//Récupération du mot de passe dans les préférences et ouverture de session avec le serveur
session.setPassword(passwordFtp);
session.connect();
//Configuration du canal en mode sFTP et ouverture
Channel channel = session.openChannel("sftp");
sftpChannel = (ChannelSftp) channel;
sftpChannel.connect();
//Initialisation de la notification
initialiseNotif();
//Lancement du téléchargement des fichiers
downloadFiles();
//Clôture de la connexion
sftpChannel.disconnect();
}
} catch (JSchException e) {
Log.e("JschException", e.toString());
} catch (SftpException e) {
Log.e("SftpException", e.toString());
}
}
private void downloadFiles() throws SftpException
{
Vector<ChannelSftp.LsEntry> file;
//Pour chaque fichier
for( String tempFileName : downloadList)
{
if(fileExisting(tempFileName)) {
//Récupération des infos fichier
file = sftpChannel.ls(tempFileName);
currentFileSize = file.get(0).getAttrs().getSize();
currentFileName = file.get(0).getFilename();
broadcastIntentRD.putExtra(GlobalEnum.DOWNLOAD.FILE_NAME, currentFileName);
broadcastIntentRD.putExtra(GlobalEnum.DOWNLOAD.FILE_SIZE, currentFileSize);
//Lancement du téléchargement
int lastDot = tempFileName.lastIndexOf(".");
String baseFileName = null;
if(tempFileName.endsWith("tar.gz"))
{
String temp = tempFileName.substring(0, lastDot);
baseFileName = temp.substring(0, temp.lastIndexOf("."));
} else {
baseFileName = tempFileName.substring(0, lastDot );
}
try {
sftpChannel.get(baseFileName + ".md5", Environment.getExternalStorageDirectory() + vamsillaPath + "/" + baseFileName + ".md5");
} catch (SftpException e) {
Log.v("Sftp", "md5 introuvable pour : " + currentFileName);
}
sftpChannel.get(file.get(0).getFilename(), Environment.getExternalStorageDirectory() + vamsillaPath + "/" + file.get(0).getFilename(),this);
}
}
RunningDownloadsActivity:
public class DownloadReceiverRD extends BroadcastReceiver{
@Override
public void onReceive(Context context, Intent intent) {
//BLABLA for notification and progressbar update
if(progress == fileSize){
//BLABLA for notification and progressbar closing
md5Sum(fileName);
}
}
private void md5Sum(String currentFileName) {
VamsillaTools tools = new VamsillaTools(getApplicationContext());
//Ouverture de la base de stockage des fichiers
//Insertion du résultat dans la BDD
int result = tools.checkMD5(currentFileName);
db.insertFile(currentFileName, result);
switch(result) {
case -1 : Log.v("MD5", "Problème lors de la comparaison md5 : " + currentFileName); break;
case 0 : Log.v("MD5", "Comparaison md5 fausse : " + currentFileName); break;
case 1 : Log.v("MD5", "Succès de la comparaison md5 pour : " + currentFileName);
/********
SUPRESS THE FILE HERE WOULD BE PERFECT !!!
*********/
break;
}
}
}
Прошу прощения за мой английский, я французский, и вы знаете, насколько мы хороши для иностранных языков...
Спасибо!
1 ответ
Возможно, уже поздно, но если это может кому-то помочь... Я наконец-то оправдал создание класса, наследующего от Thread, выполняющего работу по сети + удаление файла, когда мы прекращаем поиск сложных путей, это довольно просто:)