PHP ActiveX
PHP ActiveX
OneNote - Create Page
See more OneNote Examples
Creates a new OneNote page with a rendered image and an attached PDF.Chilkat PHP ActiveX Downloads
<?php
$success = 0;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
$http = new COM("Chilkat.Http");
// To create a OneNote page, we want to send an HTTP request like the following:
// POST https://graph.microsoft.com/v1.0/me/onenote/sections/{section_id}/pages
// Content-length: 312
// Content-type: multipart/form-data; boundary=MyPartBoundary198374
//
// --MyPartBoundary198374
// Content-Disposition:form-data; name="Presentation"
// Content-Type:text/html
//
// <!DOCTYPE html>
// <html>
// <head>
// <title>A page with <i>rendered</i> images and an <b>attached</b> file</title>
// <meta name="created" content="2015-07-22T09:00:00-08:00" />
// </head>
// <body>
// <p>Here's an image from an online source:</p>
// <img src="https://..." alt="an image on the page" width="500" />
// <p>Here's an image uploaded as binary data:</p>
// <img src="name:imageBlock1" alt="an image on the page" width="300" />
// <p>Here's a file attachment:</p>
// <object data-attachment="FileName.pdf" data="name:fileBlock1" type="application/pdf" />
// </body>
// </html>
//
// --MyPartBoundary198374
// Content-Disposition:form-data; name="imageBlock1"
// Content-Type:image/jpeg
//
// ... binary image data ...
//
// --MyPartBoundary198374
// Content-Disposition:form-data; name="fileBlock1"
// Content-Type:application/pdf
//
// ... binary file data ...
//
// --MyPartBoundary198374--
// Build the request in a Chilkat HTTP request object:
$req = new COM("Chilkat.HttpRequest");
// Our URL is https://graph.microsoft.com/v1.0/me/onenote/sections/{section_id}/pages
// The path part of the URL is "/v1.0/me/onenote/sections/{section_id}/pages"
// In this example, our section ID is "0-3A33FCEB9B74CC15!20350"
$req->Path = '/v1.0/me/onenote/sections/0-3A33FCEB9B74CC15!20350/pages';
// We'll be sending a POST.
$req->HttpVerb = 'POST';
// The Content-Type is multipart/form-data
// Chilkat will automatically generate a boundary string.
$req->ContentType = 'multipart/form-data';
// When Chilkat HTTP was written many years ago, multipart requests were primarily for uploads.
// Thus the names of methods that add a multipart section end with "ForUpload".
// The multipart request we wish to build has 3 sections: text/html, image/jpeg, and application/pdf.
// ------------------------------
// Add the text/html part.
// ------------------------------
$sbHtml = new COM("Chilkat.StringBuilder");
$bCrlf = 1;
$sbHtml->AppendLine('<!DOCTYPE html>',$bCrlf);
$sbHtml->AppendLine('<html>',$bCrlf);
$sbHtml->AppendLine(' <head>',$bCrlf);
$sbHtml->AppendLine(' <title>A page with <i>rendered</i> images and an <b>attached</b> file</title>',$bCrlf);
$sbHtml->AppendLine(' <meta name=\'created\' content=\'TIMESTAMP_CURRENT\' />',$bCrlf);
$sbHtml->AppendLine(' </head>',$bCrlf);
$sbHtml->AppendLine(' <body>',$bCrlf);
$sbHtml->AppendLine(' <p>Here's an image from an online source:</p>',$bCrlf);
$sbHtml->AppendLine(' <img src=\'https://www.chilkatsoft.com/images/starfish.jpg\' alt=\'an image on the page\' width=\'500\' />',$bCrlf);
$sbHtml->AppendLine(' <p>Here's an image uploaded as binary data:</p>',$bCrlf);
$sbHtml->AppendLine(' <img src=\'name:imageBlock1\' alt=\'an image on the page\' width=\'300\' />',$bCrlf);
$sbHtml->AppendLine(' <p>Here's a file attachment:</p>',$bCrlf);
$sbHtml->AppendLine(' <object data-attachment=\'FileName.pdf\' data=\'name:fileBlock1\' type=\'application/pdf\' />',$bCrlf);
$sbHtml->AppendLine(' </body>',$bCrlf);
$sbHtml->AppendLine('</html>',$bCrlf);
$dtNow = new COM("Chilkat.CkDateTime");
$dtNow->SetFromCurrentSystemTime();
$numReplaced = $sbHtml->Replace('TIMESTAMP_CURRENT',$dtNow->getAsTimestamp(1));
$req->AddStringForUpload2('Presentation','',$sbHtml->getAsString(),'utf-8','text/html');
// ------------------------------
// Add the JPG image.
// ------------------------------
$success = $req->AddFileForUpload2('imageBlock1','qa_data/jpg/penguins2.jpg','image/jpeg');
if ($success == 0) {
print $req->LastErrorText . "\n";
exit;
}
// ------------------------------
// Add the PDF attachment.
// ------------------------------
$bdPdf = new COM("Chilkat.BinData");
$success = $bdPdf->LoadFile('qa_data/pdf/helloWorld.pdf');
if ($success == 0) {
print 'Failed to load PDF file.' . "\n";
exit;
}
$success = $req->AddBdForUpload('fileBlock1','FileName.pdf',$bdPdf,'application/pdf');
if ($success == 0) {
print $req->LastErrorText . "\n";
exit;
}
// Adds the "Authorization: Bearer ACCESS_TOKEN" header.
$http->AuthToken = 'ACCESS_TOKEN';
// POST to https://graph.microsoft.com/v1.0/me/onenote/sections/{section_id}/pages
// The path part of the URL is already specified in the req object.
// We only need to specify the domain and the fact that we're doing "https" (SSL/TLS).
$resp = new COM("Chilkat.HttpResponse");
$success = $http->HttpSReq('graph.microsoft.com',443,1,$req,$resp);
if ($success == 0) {
print $http->LastErrorText . "\n";
exit;
}
$sbResponseBody = new COM("Chilkat.StringBuilder");
$resp->GetBodySb($sbResponseBody);
$jResp = new COM("Chilkat.JsonObject");
$jResp->LoadSb($sbResponseBody);
$jResp->EmitCompact = 0;
print 'Response status code: ' . $resp->StatusCode . "\n";
print 'Response Body:' . "\n";
print $jResp->emit() . "\n";
$respStatusCode = $resp->StatusCode;
print 'Response Status Code = ' . $respStatusCode . "\n";
if ($respStatusCode >= 400) {
print 'Response Header:' . "\n";
print $resp->Header . "\n";
print 'Failed.' . "\n";
exit;
}
// Sample JSON response:
// (Sample code for parsing the JSON response is shown below)
// {
// "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users('admin%40chilkat.io')/onenote/sections('0-3A33FCEB9B74CC15%2120350')/pages/$entity",
// "id": "0-18ac61117a664f7e946bcceaeebd6f57!36-3A33FCEB9B74CC15!20350",
// "self": "https://graph.microsoft.com/v1.0/users/admin@chilkat.io/onenote/pages/0-18ac61117a664f7e946bcceaeebd6f57!36-3A33FCEB9B74CC15!20350",
// "createdDateTime": "2020-10-22T19:02:12Z",
// "title": "A page with rendered images and an attached file",
// "createdByAppId": "WLID-00000000441C9990",
// "contentUrl": "https://graph.microsoft.com/v1.0/users/admin@chilkat.io/onenote/pages/0-18ac61117a664f7e946bcceaeebd6f57!36-3A33FCEB9B74CC15!20350/content",
// "lastModifiedDateTime": "2020-10-23T00:02:13.3254289Z",
// "links": {
// "oneNoteClientUrl": {
// "href": "onenote:https://d.docs.live.net/3a33fceb9b74cc15/Documents/Testing%20Notebook/Ddd.one#A%20page%20with%20rendered%20images%20and%20an%20attached%20file§ion-id=9d78c221-486e-45f8-8355-1810e475f6c0&page-id=36cd1982-1ef1-4b11-b5a1-30b3dbc43d05&end"
// },
// "oneNoteWebUrl": {
// "href": "https://onedrive.live.com/redir.aspx?cid=3a33fceb9b74cc15&page=edit&resid=3A33FCEB9B74CC15!20344&parId=3A33FCEB9B74CC15!187&wd=target%28Ddd.one%7C9d78c221-486e-45f8-8355-1810e475f6c0%2FA%20page%20with%20rendered%20images%20and%20an%20attached%20file%7C36cd1982-1ef1-4b11-b5a1-30b3dbc43d05%2F%29"
// }
// }
// }
// Sample code for parsing the JSON response...
// Use the following online tool to generate parsing code from sample JSON:
// Generate Parsing Code from JSON
$odata_context = $jResp->stringOf('\'@odata.context\'');
$id = $jResp->stringOf('id');
$self = $jResp->stringOf('self');
$createdDateTime = $jResp->stringOf('createdDateTime');
$title = $jResp->stringOf('title');
$createdByAppId = $jResp->stringOf('createdByAppId');
$contentUrl = $jResp->stringOf('contentUrl');
$lastModifiedDateTime = $jResp->stringOf('lastModifiedDateTime');
$linksOneNoteClientUrlHref = $jResp->stringOf('links.oneNoteClientUrl.href');
$linksOneNoteWebUrlHref = $jResp->stringOf('links.oneNoteWebUrl.href');
?>