Sample code for 30+ languages & platforms
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.folder

See Google Drive Files: create for more details.

Also See Working with Folders for more details.

Chilkat Java Downloads

Java
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"));
  }
}