मैंने एक एसडी कार्ड पर अपने डेटाबेस का बैकअप बनाने में कामयाब रहा है और वहां से बहाल किया है लेकिन मुझे एहसास हुआ कि मेरे बैकअप का उद्देश्य डेटा की सुरक्षा सुनिश्चित करना है और इसमें अगर भौतिक उपकरण स्वयं क्षतिग्रस्त, खो गया है, या स्वचालित रूप से दहन करता है तो एसडी कार्ड पर बैकअप होगा। इसलिए इस मामले में मूल के समान स्थान पर बैकअप रखना, बैकअप लेने के उद्देश्य से काफी हद तक हरा देता है।SQL ड्राइव डेटाबेस को पुनर्स्थापित करने और पुनर्स्थापित करने के लिए Google ड्राइव का उपयोग
तो मैंने डीबी फ़ाइल को रखने के लिए एक सुरक्षित स्थान के रूप में Google ड्राइव का उपयोग करने का विचार किया, और यह मुफ़्त है। मैंने Google के quickstart डेमो में एक झलक लिया है जिसे मैं ठीक काम कर रहा हूं। लेकिन मुझे अभी भी पता नहीं है कि यह मेरे मामले के लिए कैसे किया जाए।
मुझे कुछ कोड मिल गया है लेकिन यह अभी भी कुछ बहिष्कृत तरीकों का उपयोग कर रहा है और अब तक मैंने इसे हटाए गए क्षेत्र को छोड़ते समय इसे चलाने में कामयाब रहा है, लेकिन यह केवल मेरे Google ड्राइव में एक खाली बाइनरी फ़ाइल बनाता है। लगता है कि बहिष्कृत क्षेत्र वह जगह है जहां यह वास्तव में डीबी बैकअप सामग्री अपलोड करता है। अगर कोई मदद कर सकता है तो इसकी बहुत सराहना की जाएगी।
अगर मैं इसे बेहतर तरीके से समझाने के लिए इसका उपयोग कर सकता हूं तो मैं इसे नीचे छोड़ दूंगा। मैंने नीचे बहिष्कृत विधि भी चिह्नित की है, यह अंत के करीब है।
public class ExpectoPatronum extends Activity implements ConnectionCallbacks, OnConnectionFailedListener {
private static final String TAG = "MainActivity";
private GoogleApiClient api;
private boolean mResolvingError = false;
private DriveFile mfile;
private static final int DIALOG_ERROR_CODE =100;
private static final String DATABASE_NAME = "demodb";
private static final String GOOGLE_DRIVE_FILE_NAME = "sqlite_db_backup";
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// Create the Drive API instance
api = new GoogleApiClient.Builder(this).addApi(Drive.API).addScope(Drive.SCOPE_FILE).
addConnectionCallbacks(this).addOnConnectionFailedListener(this).build();
}
@Override
public void onStart() {
super.onStart();
if(!mResolvingError) {
api.connect(); // Connect the client to Google Drive
}
}
@Override
public void onStop() {
super.onStop();
api.disconnect(); // Disconnect the client from Google Drive
}
@Override
public void onConnectionFailed(ConnectionResult result) {
Log.v(TAG, "Connection failed");
if(mResolvingError) { // If already in resolution state, just return.
return;
} else if(result.hasResolution()) { // Error can be resolved by starting an intent with user interaction
mResolvingError = true;
try {
result.startResolutionForResult(this, DIALOG_ERROR_CODE);
} catch (SendIntentException e) {
e.printStackTrace();
}
} else { // Error cannot be resolved. Display Error Dialog stating the reason if possible.
ErrorDialogFragment fragment = new ErrorDialogFragment();
Bundle args = new Bundle();
args.putInt("error", result.getErrorCode());
fragment.setArguments(args);
fragment.show(getFragmentManager(), "errordialog");
}
}
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
if(requestCode == DIALOG_ERROR_CODE) {
mResolvingError = false;
if(resultCode == RESULT_OK) { // Error was resolved, now connect to the client if not done so.
if(!api.isConnecting() && !api.isConnected()) {
api.connect();
}
}
}
}
@Override
public void onConnected(Bundle connectionHint) {
Log.v(TAG, "Connected successfully");
/* Connection to Google Drive established. Now request for Contents instance, which can be used to provide file contents.
The callback is registered for the same. */
Drive.DriveApi.newDriveContents(api).setResultCallback(contentsCallback);
}
final private ResultCallback<DriveApi.DriveContentsResult> contentsCallback = new ResultCallback<DriveApi.DriveContentsResult>() {
@Override
public void onResult(DriveApi.DriveContentsResult result) {
if (!result.getStatus().isSuccess()) {
Log.v(TAG, "Error while trying to create new file contents");
return;
}
String mimeType = MimeTypeMap.getSingleton().getExtensionFromMimeType("db");
MetadataChangeSet changeSet = new MetadataChangeSet.Builder()
.setTitle(GOOGLE_DRIVE_FILE_NAME) // Google Drive File name
.setMimeType(mimeType)
.setStarred(true).build();
// create a file on root folder
Drive.DriveApi.getRootFolder(api)
.createFile(api, changeSet, result.getDriveContents())
.setResultCallback(fileCallback);
}
};
final private ResultCallback<DriveFileResult> fileCallback = new ResultCallback<DriveFileResult>() {
@Override
public void onResult(DriveFileResult result) {
if (!result.getStatus().isSuccess()) {
Log.v(TAG, "Error while trying to create the file");
return;
}
mfile = result.getDriveFile();
mfile.open(api, DriveFile.MODE_WRITE_ONLY, null).setResultCallback(contentsOpenedCallback);
}
};
final private ResultCallback<DriveApi.DriveContentsResult> contentsOpenedCallback = new ResultCallback<DriveApi.DriveContentsResult>() {
@Override
public void onResult(DriveApi.DriveContentsResult result) {
if (!result.getStatus().isSuccess()) {
Log.v(TAG, "Error opening file");
return;
}
try {
FileInputStream is = new FileInputStream(getDbPath());
BufferedInputStream in = new BufferedInputStream(is);
byte[] buffer = new byte[8 * 1024];
DriveContents content = result.getDriveContents();
BufferedOutputStream out = new BufferedOutputStream(content.getOutputStream());
int n = 0;
while((n = in.read(buffer)) > 0) {
out.write(buffer, 0, n);
}
in.close();
commitAndCloseContents is DEPRECATED -->/**mfile.commitAndCloseContents(api, content).setResultCallback(new ResultCallback<Status>() {
@Override
public void onResult(Status result) {
// Handle the response status
}
});**/
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
};
private File getDbPath() {
return this.getDatabasePath(DATABASE_NAME);
}
@Override
public void onConnectionSuspended(int cause) {
// TODO Auto-generated method stub
Log.v(TAG, "Connection suspended");
}
public void onDialogDismissed() {
mResolvingError = false;
}
public static class ErrorDialogFragment extends DialogFragment {
public ErrorDialogFragment() {}
public Dialog onCreateDialog(Bundle savedInstanceState) {
int errorCode = this.getArguments().getInt("error");
return GooglePlayServicesUtil.getErrorDialog(errorCode, this.getActivity(), DIALOG_ERROR_CODE);
}
public void onDismiss(DialogInterface dialog) {
((ExpectoPatronum) getActivity()).onDialogDismissed();
}
}
}
सुनिश्चित करें कि आप ड्राइव बाकी एपीआई और GDAA के बीच अंतर को समझते हैं। आपके उपयोग के मामले के लिए, gdaa जाना सबसे अच्छा तरीका है, तो आप किसी भी जल्दी शुरू ट्यूटोरियल कि gdaa नहीं है अनदेखा कर देना चाहिए। एक तरफ, एक प्रश्न में इतना कोड पोस्ट करना बहुत उपयोगी नहीं है। – pinoyyid
इसे देखें: http://stackoverflow.com/questions/33602812/backup-restore-sqllite-database-to-google-drive-app-folder/39044477#39044477 – Jose19589