Classic ASP
Classic ASP
OneDrive -- Create a New Folder
See more OneDrive Examples
Demonstrates how to create a new folder.Chilkat Classic ASP Downloads
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<%
success = 0
' This example requires the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.
' This example uses the OAuth client credentials flow.
' See How to Create an Azure App Registration for OAuth 2.0 Client Credentials
' Use your client ID, client secret, and tenant ID in the following lines
set json = Server.CreateObject("Chilkat.JsonObject")
success = json.UpdateString("client_id","2871da2c-8176-4b7f-869b-2311aa82e743")
success = json.UpdateString("client_secret","2hu9Q~r5QuryUcEkNbg1btLtnfU1VUXzhSCG6brH")
success = json.UpdateString("scope","https://graph.microsoft.com/.default")
success = json.UpdateString("token_endpoint","https://login.microsoftonline.com/114d7ed6-71bf-4dbe-a866-748364121bf2/oauth2/v2.0/token")
set http = Server.CreateObject("Chilkat.Http")
http.AuthToken = json.Emit()
' To create a new folder, send a POST request like this:
' POST /users/{user-id}/drive/items/{parent-item-id}/children
' We first need to get the item-id for the folder where the new folder will be created.
' This example will create a new folder named "abc" within /TestDir,
' so we need the item-id for /TestDir.
success = http.SetUrlVar("dir_path","/TestDir")
success = http.SetUrlVar("user_id","4fe732c3-322e-4a6b-b729-2fd1eb5c6104")
respStr = http.QuickGetStr("https://graph.microsoft.com/v1.0/users/{$user_id}/drive/root:{$dir_path}")
If (http.LastMethodSuccess = 0) Then
Response.Write "<pre>" & Server.HTMLEncode( http.LastErrorText) & "</pre>"
Response.End
End If
success = json.Load(respStr)
If (http.LastStatus <> 200) Then
Response.Write "<pre>" & Server.HTMLEncode( "Failed to get parent folder item id, status code = " & http.LastStatus) & "</pre>"
Response.End
End If
' The HTTP request body should contain JSON like this:
' {
' "name": "abc",
' "folder": { }
' }
set jsonReqBody = Server.CreateObject("Chilkat.JsonObject")
success = jsonReqBody.AppendString("name","abc")
set jObj = Server.CreateObject("Chilkat.JsonObject")
success = jsonReqBody.AppendObject2("folder",jObj)
Response.Write "<pre>" & Server.HTMLEncode( "JSON body:") & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( jsonReqBody.Emit()) & "</pre>"
' Set the URL var for the next request which will create the new folder.
success = http.SetUrlVar("parent_item_id",json.StringOf("id"))
url = "https://graph.microsoft.com/v1.0/users/{$user_id}/drive/items/{$parent_item_id}/children"
set resp = Server.CreateObject("Chilkat.HttpResponse")
success = http.HttpJson("POST",url,jsonReqBody,"application/json",resp)
If (success = 0) Then
Response.Write "<pre>" & Server.HTMLEncode( http.LastErrorText) & "</pre>"
Response.End
End If
success = json.Load(resp.BodyStr)
Response.Write "<pre>" & Server.HTMLEncode( "Response:") & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( json.Emit()) & "</pre>"
' A 201 response indicates success.
If (resp.StatusCode <> 201) Then
Response.Write "<pre>" & Server.HTMLEncode( "Failed to create folder.") & "</pre>"
Response.Write "<pre>" & Server.HTMLEncode( "Response status code = " & resp.StatusCode) & "</pre>"
Else
Response.Write "<pre>" & Server.HTMLEncode( "Successfully created folder.") & "</pre>"
End If
' A successful response:
' {
' "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users('me')/drive/items('3A33FCEB9B74CC15%214862')/children/$entity",
' "createdBy": {
' "application": {
' "displayName": "Chilkat",
' "id": "441c9990"
' },
' "user": {
' "displayName": "Matt Smith",
' "id": "3a33fceb9b74cc15"
' }
' },
' "createdDateTime": "2017-06-04T16:02:22.203Z",
' "cTag": "adDozQTMzRkNFQjlCNzRDQzE1ITQ4NzAuNjM2MzIxODg5NDIyMDMwMDAw",
' "eTag": "aM0EzM0ZDRUI5Qjc0Q0MxNSE0ODcwLjA",
' "id": "3A33FCEB9B74CC15!4870",
' "lastModifiedBy": {
' "application": {
' "displayName": "Chilkat",
' "id": "441c9990"
' },
' "user": {
' "displayName": "Matt Smith",
' "id": "3a33fceb9b74cc15"
' }
' },
' "lastModifiedDateTime": "2017-06-04T16:02:22.203Z",
' "name": "abc",
' "parentReference": {
' "driveId": "3a33fceb9b74cc15",
' "id": "3A33FCEB9B74CC15!4862",
' "name": "someFolder",
' "path": "/drive/root:/someFolder"
' },
' "size": 0,
' "webUrl": "https://1drv.ms/f/s!ABXMdJvr_DM6pgY",
' "fileSystemInfo": {
' "createdDateTime": "2017-06-04T16:02:22.203Z",
' "lastModifiedDateTime": "2017-06-04T16:02:22.203Z"
' },
' "folder": {
' "childCount": 0
' }
' }
'
' Successfully created folder.
%>
</body>
</html>