GoogleDrive APIを使用するアップロードの進行状況を確認するにはどうすればよいですか?
service.files()。insert(body、mediaContent).execute();のみが返されますafileこれは、ファイルが完全にアップロードされているかどうかを確認できます。
しかし、とにかくそれを行うには、リアルタイムで(少なくとも毎秒程度)進行状況を確認する必要がありますか?
また、ダウンロード部分については、入力ストリームから既に読み取ったバイト数を合計ファイルサイズと手動で比較して、現在の進行状況を計算できると思います。
しかし、これは正しい方法ですか?または、進行状況を確認する他のより良い方法がありますか?
private void saveFileToDrive() {
Thread t = new Thread(new Runnable() {
@Override
public void run() {
try {
// File's binary content
Java.io.File fileContent = new Java.io.File(fileUri.getPath());
FileContent mediaContent = new FileContent("image/jpeg", fileContent);
// File's metadata.
File body = new File();
body.setTitle(fileContent.getName());
body.setMimeType("image/jpeg");
File file = service.files().insert(body, mediaContent).execute();
if (file != null) {
showToast("Photo uploaded: " + file.getTitle());
//startCameraIntent();
}
} catch (UserRecoverableAuthIOException e) {
startActivityForResult(e.getIntent(), REQUEST_AUTHORIZATION);
} catch (IOException e) {
e.printStackTrace();
}
}
});
t.start();
}
再開可能なアップロードを使用している場合、チャンクサイズを1MBに設定すると、ある程度の進歩を遂げることができます。 。しかし、現在2つの問題があります。
1)再開可能なアップロードは、その間に何度も停止し、毎回1MBしか送信しないため、単一のアップロードよりもはるかに低速です。
chunksizeをより高く設定すると、小さいファイルでは進行状況がまったく表示されません。
したがって、再開可能なアップロードの進捗状況は、私が実際に望んでいるものではありません。 1回のアップロードで進捗が欲しい。
2)チャンクサイズを約1MBに設定すると、通常の10MBファイルのアップロードは常にfailで約70%になります。
チャンクサイズを10MBに設定すると成功しますが、進捗は見られません。
Drive.Files.Insert insert = service.files().insert(body, mediaContent);
MediaHttpUploader uploader = insert.getMediaHttpUploader();
uploader.setDirectUploadEnabled(false);
uploader.setChunkSize(10*1024*1024); // previously I am using 1000000 thats why it won't work
uploader.setProgressListener(new FileUploadProgressListener());
com.google.api.services.drive.model.File f = insert.execute();
LogCatエラー:
11-27 19:23:26.927: D/FileUploadProgressListener(11527): Upload is In Progress: 0.5235538030501893
11-27 19:23:33.692: D/FileUploadProgressListener(11527): Upload is In Progress: 0.56095050326806
11-27 19:23:38.294: D/FileUploadProgressListener(11527): Upload is In Progress: 0.5983472034859306
11-27 19:23:50.583: D/FileUploadProgressListener(11527): Upload is In Progress: 0.6357439037038013
11-27 19:23:55.091: D/FileUploadProgressListener(11527): Upload is In Progress: 0.673140603921672
11-27 19:24:05.130: D/FileUploadProgressListener(11527): Upload is In Progress: 0.7105373041395426
11-27 19:24:17.005: D/FileUploadProgressListener(11527): Upload is In Progress: 0.7479340043574133
11-27 19:24:28.888: D/FileUploadProgressListener(11527): Upload is In Progress: 0.785330704575284
11-27 19:24:28.896: W/HttpTransport(11527): exception thrown while executing request
11-27 19:24:28.896: W/HttpTransport(11527): Java.io.IOException: unexpected end of stream
11-27 19:24:28.896: W/HttpTransport(11527): at libcore.net.http.FixedLengthOutputStream.close(FixedLengthOutputStream.Java:58)
11-27 19:24:28.896: W/HttpTransport(11527): at com.google.api.client.http.javanet.NetHttpRequest.execute(NetHttpRequest.Java:88)
11-27 19:24:28.896: W/HttpTransport(11527): at com.google.api.client.http.HttpRequest.execute(HttpRequest.Java:980)
11-27 19:24:28.896: W/HttpTransport(11527): at com.google.api.client.googleapis.media.MediaHttpUploader.upload(MediaHttpUploader.Java:293)
11-27 19:24:28.896: W/HttpTransport(11527): at com.google.api.services.drive.Drive$Files$Insert.executeUnparsed(Drive.Java:309)
11-27 19:24:28.896: W/HttpTransport(11527): at com.google.api.services.drive.Drive$Files$Insert.execute(Drive.Java:331)
プログレスリスナー:
private class FileUploadProgressListener implements MediaHttpUploaderProgressListener {
private String mFileUploadedName;
public FileUploadProgressListener(String fileName) {
mFileUploadedName = fileName;
}
@Override
public void progressChanged(MediaHttpUploader mediaHttpUploader) throws IOException {
if (mediaHttpUploader == null) return;
switch (mediaHttpUploader.getUploadState()) {
case INITIATION_STARTED:
//System.out.println("Initiation has started!");
break;
case INITIATION_COMPLETE:
//System.out.println("Initiation is complete!");
break;
case MEDIA_IN_PROGRESS:
double percent = mediaHttpUploader.getProgress() * 100;
if (Ln.DEBUG) {
Log.d(Ln.TAG, "Upload to Dropbox: " + mFileUploadedName + " - " + String.valueOf(percent) + "%");
}
notif.setProgress(percent, mFileUploadedName).fire();
break;
case MEDIA_COMPLETE:
//System.out.println("Upload is complete!");
}
}
}
詳細はこちら: https://code.google.com/p/google-api-Java-client/wiki/MediaUpload
メディアの直接アップロードは、メディアコンテンツ全体をアップロードします1つのリクエストで複数のリクエストでアップロードできる再開可能なメディアアップロードプロトコルとは対照的です。
直接アップロードを行うと、HTTPリクエストの数は減りますが、失敗の変化が増えるメディアのアップロードが大きい場合(接続の失敗など)。
ライブラリのアーキテクチャにより、チャンクと進行状況のどちらかを選択する必要がありますOR進行なしの1ステップ。最小のチャンクサイズで改善されるはずです。可能な限り小さいチャンク:
setChunkSize(MediaHttpUploader.MINIMUM_CHUNK_SIZE)
それが役に立てば幸い!
チャンクサイズに関しては、MediaHttpUploader.MINIMUM_CHUNK_SIZEの倍数である必要があるため、以前の値でエラーが発生しました。
元のアプローチの代わりにCloudRailSDKを使用したわずかに異なるアプローチ。次のProgressInputStreamは、アップロードとダウンロードの進行状況の表示に使用できます。
class ProgressInputStream extends InputStream {
private InputStream stream;
private ProgressListener progressListener;
private long offset = 0;
public ProgressInputStream(InputStream stream, UploadProgressListener progressListener) {
this.stream = stream;
this.progressListener = progressListener;
}
@Override
public int read() throws IOException {
int res = this.stream.read();
this.progressListener.onProgressChanged(++this.offset);
return res;
}
@Override
public int read(byte[] b, int off, int len) throws IOException {
int res = this.stream.read(b, off, len);
this.offset += res;
this.progressListener.onProgressChanged(this.offset);
return res;
}
// You might need to override additional methods but you can just
// call the corresponding method on the stream property
public interface ProgressListener {
void onProgressChanged(long bytes);
}
}
完全なチュートリアルは ここ にあります。