私はAndroidアプリに取り組んでおり、Googleドライブをアプリに統合しようとしています。プログラムは同期を許可するため、SDカードにファイルが作成され、このファイルがGoogleドライブにアップロードされます。認証に成功しましたが、insert
関数を使用してアップロードするとNullPointerExceptionが発生し、すべてをステップスルーしたときにnullのように見えるものがないため、値がnullの場所を確認できません。
以下は、アップロードを実行するために使用しているコードです。
private void uploadToDrive()
{
Thread thread = new Thread(new Runnable() {
public void run() {
try
{
SharedPreferences settings = context.getSharedPreferences("prefs", 0);
GoogleAccountCredential credential = GoogleAccountCredential.usingOAuth2(context, DriveScopes.DRIVE);
credential.setSelectedAccountName(settings.getString("google_drive_account_name", ""));
Drive service = getDriveService(credential);
String storageDir = Environment.getExternalStorageDirectory().getPath();
Uri fileUri = Uri.fromFile(new java.io.File(storageDir + "/folder/drive_sync.xml"));
java.io.File fileContent = new java.io.File(fileUri.getPath());
FileContent mediaContent = new FileContent("text/xml", fileContent);
com.google.api.services.drive.model.File body = new com.google.api.services.drive.model.File();
body.setTitle("My App Title");
body.setMimeType("text/xml");
com.google.api.services.drive.model.File file = service.files().insert(body, mediaContent).execute();
if (file == null)
{
Log.e("UploadFile", "File was empty after insert");
}
}
catch (UserRecoverableAuthIOException e)
{
activity.startActivityForResult(e.getIntent(), SynchronisationSettings.REQUEST_ACCOUNT_PICKER);
}
catch (IOException ex)
{
Log.d("Upload Drive", ex.toString());
ex.printStackTrace();
}
catch (Exception ex)
{
Log.d("Upload File", ex.toString());
ex.printStackTrace();
}
}
});
thread.start();
}
以下は私がドライブサービスを受ける方法です
プライベートドライブgetDriveService(GoogleAccountCredential credential){return new Drive.Builder(AndroidHttp.newCompatibleTransport()、new GsonFactory()、credential).build(); }
以下は、例外から出力されるスタックトレースです。
> 03-23 17:05:00.050: W/System.err(21664):
> java.lang.NullPointerException 03-23 17:05:00.055:
> W/System.err(21664): at java.net.URI.parseURI(URI.java:353) 03-23
> 17:05:00.055: W/System.err(21664): at
> java.net.URI.<init>(URI.java:204) 03-23 17:05:00.060:
> W/System.err(21664): at
> com.google.api.client.http.GenericUrl.<init>(GenericUrl.java:100)
> 03-23 17:05:00.065: W/System.err(21664): at
> com.google.api.client.googleapis.media.MediaHttpUploader.upload(MediaHttpUploader.java:269)
> 03-23 17:05:00.065: W/System.err(21664): at
> com.google.api.client.googleapis.services.AbstractGoogleClientRequest.executeUnparsed(AbstractGoogleClientRequest.java:408)
> 03-23 17:05:00.065: W/System.err(21664): at
> com.google.api.client.googleapis.services.AbstractGoogleClientRequest.executeUnparsed(AbstractGoogleClientRequest.java:328)
> 03-23 17:05:00.070: W/System.err(21664): at
> com.google.api.client.googleapis.services.AbstractGoogleClientRequest.execute(AbstractGoogleClientRequest.java:449)
> 03-23 17:05:00.070: W/System.err(21664): at
> com.BoardiesITSolutions.PasswordManager.Classes.DriveSync$1.run(DriveSync.java:85)
> 03-23 17:05:00.070: W/System.err(21664): at
> java.lang.Thread.run(Thread.java:856)