Java
Java
Create Folder
See more Google Drive Examples
In the Drive API, a folder is essentially a file — one identified by the special folder MIME type application/vnd.google-apps.folderSee Google Drive Files: create for more details.
Also See Working with Folders for more details.
Chilkat Java Downloads
import com.chilkatsoft.*;
public class ChilkatExample {
static {
try {
System.loadLibrary("chilkat");
} catch (UnsatisfiedLinkError e) {
System.err.println("Native code library failed to load.\n" + e);
System.exit(1);
}
}
public static void main(String argv[])
{
boolean success = false;
// Creating a folder is technically an upload of a 0-length file
// having a MIME type of "application/vnd.google-apps.folder"
success = true;
// It requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
// This example uses a previously obtained access token having permission for the
// Google Drive scope.
CkAuthGoogle gAuth = new CkAuthGoogle();
gAuth.put_AccessToken("GOOGLE-DRIVE-ACCESS-TOKEN");
CkRest rest = new CkRest();
// Connect using TLS.
boolean bAutoReconnect = true;
success = rest.Connect("www.googleapis.com",443,true,bAutoReconnect);
// Provide the authentication credentials (i.e. the access token)
rest.SetAuthGoogle(gAuth);
// A multipart upload to Google Drive needs a multipart/related Content-Type
rest.AddHeader("Content-Type","multipart/related");
// Specify each part of the request.
// The 1st part is JSON with information about the folder.
rest.put_PartSelector("1");
rest.AddHeader("Content-Type","application/json; charset=UTF-8");
CkJsonObject json = new CkJsonObject();
json.AppendString("name","testFolder");
json.AppendString("description","A folder to contain test files.");
json.AppendString("mimeType","application/vnd.google-apps.folder");
rest.SetMultipartBodyString(json.emit());
// The 2nd part would be the file content.
// Since this is a folder, skip the 2nd part entirely and go straight to the upload..
String jsonResponse = rest.fullRequestMultipart("POST","/upload/drive/v3/files?uploadType=multipart");
if (rest.get_LastMethodSuccess() != true) {
System.out.println(rest.lastErrorText());
return;
}
// A successful response will have a status code equal to 200.
if (rest.get_ResponseStatusCode() != 200) {
System.out.println("response status code = " + rest.get_ResponseStatusCode());
System.out.println("response status text = " + rest.responseStatusText());
System.out.println("response header: " + rest.responseHeader());
System.out.println("response JSON: " + jsonResponse);
return;
}
// Show the JSON response.
json.Load(jsonResponse);
// Show the full JSON response.
json.put_EmitCompact(false);
System.out.println(json.emit());
// A successful response looks like this:
// {
// "kind": "drive#file",
// "id": "0B53Q6OSTWYolY2tPU1BnYW02T2c",
// "name": "testFolder",
// "mimeType": "application/vnd.google-apps.folder"
// }
// Get the fileId:
System.out.println("fileId: " + json.stringOf("id"));
}
}