0

我正在尝试以.vcf编程方式将现有文件上传到 Google Drive。到目前为止,它只保存一个空文件。

这可能很简单,但我不熟悉 Google Drive Api。这是代码:

    // Perform I/O off the UI thread.
    new Thread() {
        @Override
        public void run() {
            // write content to DriveContents
            File f = new File("גיבוי אנשי קשר" + ".vcf");
            filepath = f.getAbsolutePath().toString();


            //String inFileName = Environment.getExternalStorageDirectory().getPath() + "גיבוי אנשי קשר" + ".vcf" ;
            String inFileName = filepath;
            File backupFile = new File(inFileName);
            FileInputStream inputStream = null;
            try {
                inputStream = new FileInputStream(backupFile);
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            }
            BufferedInputStream bufferedInputStream = new BufferedInputStream(inputStream);
            byte[] buffer = new byte[8 * 1024];

            BufferedOutputStream bufferedOutputStream = new BufferedOutputStream(driveContents.getOutputStream());
            int n = 0;
            try {
                while ((n = bufferedInputStream.read(buffer)) > 0) {
                    bufferedOutputStream.write(buffer, 0, n);
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
            try {
                bufferedInputStream.close();
            } catch (IOException e) {
                e.printStackTrace();
            }

            //final MimeTypeMap mime = MimeTypeMap.getSingleton();
           // String tmptype = mime.getMimeTypeFromExtension("vcf");
            MetadataChangeSet changeSet = new MetadataChangeSet.Builder()
                    .setTitle("גיבוי אנשי קשר")
                   .setMimeType("text/x-vcard")
                    .setStarred(true).build();
4

2 回答 2

1

检查您将使用Files.create上传文件的上传文件。

请务必指定,uploadType因为它是必需的参数。

这是来自文档的片段:

File fileMetadata = new File();
fileMetadata.setName("photo.jpg");
java.io.File filePath = new java.io.File("files/photo.jpg");
FileContent mediaContent = new FileContent("image/jpeg", filePath);
File file = driveService.files().create(fileMetadata, mediaContent)
        .setFields("id")
        .execute();
System.out.println("File ID: " + file.getId());
于 2017-05-30T18:12:24.760 回答
0

这是我用来将“csv”文件保存为电子表格的一些代码。它需要 Drive API(用于文件夹)和 Sheets API(用于文件)。

使用此快速入门: https ://developers.google.com/drive/v3/web/quickstart/android

如果有任何问题,请询问。希望能帮助到你!

   @Override
    protected Boolean doInBackground(Void... params) {
        try {
            deviceOnline = isDeviceOnline();
            if (!deviceOnline) {
                Log.e(LOG_CONNECT, "in doInBackground() - Device is not connected to network");
                cancel(true);
                return false;
            }

            Boolean uploadToDriveSuccessfull = uploadFileToDrive();
            if (uploadToDriveSuccessfull) {
                Log.d(LOG_CONNECT, "in doInBackground() - File Uploaded To Drive = True ");
                return true;
            }
            else {
                Log.e(LOG_CONNECT, "in doInBackground() - File Uploaded To Drive = False ");
                //TODO - Upload failed - trigger second try to save to Drive
                return false;
            }
        } catch (Exception e) {
            Log.e(LOG_CONNECT, "in doInBackground() - error: " + e.getMessage());
            mLastError = e;
            cancel(true);
            return false;
        }
    }

   private Boolean uploadFileToDrive() {
       Log.d(LOG_CONNECT, "in uploadFileToDrive()");

       //Create the DriveFolderID once
       if (getDriveFolderID() == null ) {
           Log.d(LOG_CONNECT, "in uploadFileToDrive() - creating new folder");
           setDriveFolderID(createFolderInDrive());
       }

        String fileId;
        fileId = saveOneFileToDrive(mBackupFileUri,mDriveFolderId, mBackupFileName);

        if(fileId != null){
            //updates the shared pref
            setmDriveSavedFileId(fileId);
            setFileName(mBackupFileName,driveTag);
            Log.d(LOG_CONNECT, "in uploadFileToDrive() - file saved, ID: " + fileId);
            return true;
        }
        else{
            Log.e(LOG_CONNECT, "in uploadFileToDrive() - file NOT saved");
            return false;
        }
   }


    private String createFolderInDrive () {
       Log.d(LOG_CONNECT, "in createFolderInDrive()");
       File fileMetadata = new File();
       fileMetadata.setName(getString(R.string.app_name));
       fileMetadata.setMimeType("application/vnd.google-apps.folder");

       File file = null;
       try {
           file = mDriveService.files().create(fileMetadata)
                   .setFields("id")
                   .execute();
       } catch (IOException e) {
           Log.e(LOG_CONNECT, "in createFolderInDrive() - IOException: " + e.getMessage());
           e.printStackTrace();
           return null;
       }
       Log.d(LOG_CONNECT, "in createFolderInDrive() - FOLDER ID: " + file.getId());
       Log.d(LOG_CONNECT, "in createFolderInDrive() - FOLDER stared = " + file.getStarred());

       return file.getId();
   }


   //This function Save new file to Drive
   private String saveOneFileToDrive (Uri localFileUri,String driveFolderId, String fileNameOnDrive){
       Log.d(LOG_CONNECT, "in saveOneFileToDrive()");
       if (localFileUri == null) {
           Log.e(LOG_CONNECT, "in saveOneFileToDrive() - fileUri is null");
           return null;
       }

       String filePathString = localFileUri.getPath();
       Log.d(LOG_CONNECT, "in saveOneFileToDrive() - fileString= " + filePathString);
       File fileMetadata = new File();

       //Set csv file name with real one with date.
       fileMetadata.setName(fileNameOnDrive);
       String fields;
       if (driveFolderId != null) {
           Log.d(LOG_CONNECT, "in saveOneFileToDrive() - FOLDER ID is: " + driveFolderId);
           fileMetadata.setParents(Collections.singletonList(driveFolderId));
           fields = "id, parents";
       } else {
           Log.d(LOG_CONNECT, "in saveOneFileToDrive() - folder is null");
           fields = "id";
       }

       //Saving SpreadSheet - you can change it
       fileMetadata.setMimeType("application/vnd.google-apps.spreadsheet");

       java.io.File filePath = new java.io.File(filePathString);
       FileContent mediaContent = new FileContent("text/csv", filePath);
       Log.d(LOG_CONNECT, "in saveOneFileToDrive() - mediaContent size= " + mediaContent.getLength());

       //print the file to log//
       BufferedReader br = null;
       try {
           br = new BufferedReader(new FileReader(mediaContent.getFile()));
       } catch (FileNotFoundException e) {
           Log.d(LOG_CONNECT, "in saveOneFileToDrive() - FileNotFoundException= " + e.getMessage());
           e.printStackTrace();
       }
       String line = null;
       try {
           while ((line = br.readLine()) != null) {
               Log.d(LOG_CONNECT, "in saveOneFileToDrive() - File info= " + line);
           }
       } catch (IOException e) {
           Log.d(LOG_CONNECT, "in saveOneFileToDrive() - IOException= " + e.getMessage());
           e.printStackTrace();
       }
       Log.d(LOG_CONNECT, "in saveOneFileToDrive() - FINISHED PRINT");
       //End of print to log//

       File file = null;

       //updating the member value from shared pref.
       getmDriveSavedFileId();

       try {
           Log.d(LOG_CONNECT, "in saveOneFileToDrive() - starting to create file");
           file = mDriveService.files().create(fileMetadata, mediaContent)
                   .setFields(fields)
                   .execute();
       } catch (UserRecoverableAuthIOException e) {
           Log.e(LOG_CONNECT, "in saveOneFileToDrive() - UserRecoverableAuthIOException error: " + e.getCause());
           startActivityForResult(e.getIntent(), REQUEST_AUTHORIZATION);
           return null;
       } catch (IOException e) {
           Log.e(LOG_CONNECT, "in saveOneFileToDrive() - IOException error: " + e.getCause()
                   + ", message: " + e.getMessage());
           e.printStackTrace();
           return null;
       }
       Log.d(LOG_CONNECT, "in saveOneFileToDrive() - File ID: " + file.getId());
       return file.getId();
   }
于 2018-05-13T14:13:24.950 回答