Chilkat HOME Android™ Classic ASP C C++ C# Mono C# .NET Core C# C# UWP/WinRT DataFlex Delphi ActiveX Delphi DLL Visual FoxPro Java Lianja MFC Objective-C Perl PHP ActiveX PHP Extension PowerBuilder PowerShell PureBasic CkPython Chilkat2-Python Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ Visual Basic 6.0 VB.NET VB.NET UWP/WinRT VBScript Xojo Plugin Node.js Excel Go
(MFC) SharePoint -- Get File Metadata (File Size, Last-Modified Date/Time, etc.)Demonstrates how to get a file's metdata, which includes the file size, last-modified date/time, name, server relative URL, etc.
#include <CkHttp.h> #include <CkJsonObject.h> #include <CkDateTime.h> #include <CkDtObj.h> void ChilkatSample(void) { CkString strOut; // This requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkHttp http; // If SharePoint Windows classic authentication is used, then set the // Login, Password, LoginDomain, and NtlmAuth properties. http.put_Login("SHAREPOINT_USERNAME"); http.put_Password("SHAREPOINT_PASSWORD"); http.put_LoginDomain("SHAREPOINT_NTLM_DOMAIN"); http.put_NtlmAuth(true); // The more common case is to use SharePoint Online authentication (via the SPOIDCRL cookie). // If so, do not set Login, Password, LoginDomain, and NtlmAuth, and instead // establish the cookie as shown at SharePoint Online Authentication // Indicate that we want a JSON reply http.put_Accept("application/json;odata=verbose"); const char *url = "https://SHAREPOINT_HTTPS_DOMAIN/_api/web/GetFileByServerRelativeUrl('/Documents/VCAC-document.docx')"; const char *jsonReply = http.quickGetStr(url); if (http.get_LastMethodSuccess() != true) { strOut.append(http.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // Examine the file's metadata in JSON format. CkJsonObject json; json.Load(jsonReply); json.put_EmitCompact(false); // Make sure it was a success response, and that we really have metadata. // If it was an error response, then the JSON is error information.. if (http.get_LastStatus() != 200) { strOut.append(json.emit()); strOut.append("\r\n"); strOut.append("Failed."); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } strOut.append(json.emit()); strOut.append("\r\n"); strOut.append("--------"); strOut.append("\r\n"); strOut.append("Server relative URL: "); strOut.append(json.stringOf("d.ServerRelativeUrl")); strOut.append("\r\n"); int fileSize = json.IntOf("d.Length"); strOut.append("File Size = "); strOut.appendInt(fileSize); strOut.append("\r\n"); CkDateTime lastmod; lastmod.SetFromTimestamp(json.stringOf("d.TimeLastModified")); // Once we have the CkDateTime object, we can get the date/time in all sorts of formats: // Get as a RFC822 GMT string: bool bLocalTime = false; strOut.append(lastmod.getAsRfc822(bLocalTime)); strOut.append("\r\n"); // Get as an RFC822 string in the local timezone. // (remember, the daylight savings that existed at the given time in the past is applied) bLocalTime = true; strOut.append(lastmod.getAsRfc822(bLocalTime)); strOut.append("\r\n"); // Get as a 32-bit UNIX time (local or GMT..) // The Unix time is number of seconds since the Epoch, 1970-01-01 00:00:00 +0000 (UTC). int unixTime = lastmod.GetAsUnixTime(bLocalTime); strOut.append("Unix time: "); strOut.appendInt(unixTime); strOut.append("\r\n"); // One can also get the as a "DtObj" object for accessing the individual // parts of the date/time, such as month, day, year, hour, minute, etc. // The DtObj can be obtained in the GMT or local timezone: CkDtObj *dtObj = lastmod.GetDtObj(bLocalTime); if (lastmod.get_LastMethodSuccess() == false) { strOut.append("This should never really happen!"); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } strOut.appendInt(dtObj->get_Day()); strOut.append("-"); strOut.appendInt(dtObj->get_Month()); strOut.append("-"); strOut.appendInt(dtObj->get_Year()); strOut.append(" "); strOut.appendInt(dtObj->get_Hour()); strOut.append(":"); strOut.appendInt(dtObj->get_Minute()); strOut.append(":"); strOut.appendInt(dtObj->get_Second()); strOut.append("\r\n"); delete dtObj; // ------------------------------------------------- // The file's metadata look like this: // { // "d": { // "__metadata": { // "id": "Web/GetFileByServerRelativeUrl('/Documents/VCAC-document.docx')", // "uri": "https://SHAREPOINT_HTTPS_DOMAIN/_api/Web/GetFileByServerRelativeUrl('/Documents/VCAC-document.docx')", // "type": "SP.File" // }, // "Author": { // "__deferred": { // "uri": "https://SHAREPOINT_HTTPS_DOMAIN/_api/Web/GetFileByServerRelativeUrl('/Documents/VCAC-document.docx')/Author" // } // }, // "CheckedOutByUser": { // "__deferred": { // "uri": "https://SHAREPOINT_HTTPS_DOMAIN/_api/Web/GetFileByServerRelativeUrl('/Documents/VCAC-document.docx')/CheckedOutByUser" // } // }, // "ListItemAllFields": { // "__deferred": { // "uri": "https://SHAREPOINT_HTTPS_DOMAIN/_api/Web/GetFileByServerRelativeUrl('/Documents/VCAC-document.docx')/ListItemAllFields" // } // }, // "LockedByUser": { // "__deferred": { // "uri": "https://SHAREPOINT_HTTPS_DOMAIN/_api/Web/GetFileByServerRelativeUrl('/Documents/VCAC-document.docx')/LockedByUser" // } // }, // "ModifiedBy": { // "__deferred": { // "uri": "https://SHAREPOINT_HTTPS_DOMAIN/_api/Web/GetFileByServerRelativeUrl('/Documents/VCAC-document.docx')/ModifiedBy" // } // }, // "Versions": { // "__deferred": { // "uri": "https://SHAREPOINT_HTTPS_DOMAIN/_api/Web/GetFileByServerRelativeUrl('/Documents/VCAC-document.docx')/Versions" // } // }, // "CheckInComment": "", // "CheckOutType": 2, // "ContentTag": "{E2F05E75-B3EF-4826-8284-E572D3628A7D},9,10", // "CustomizedPageStatus": 0, // "ETag": "\"{E2F05E75-B3EF-4826-8284-E572D3628A7D},9\"", // "Exists": true, // "Length": "21082", // "Level": 2, // "MajorVersion": 0, // "MinorVersion": 3, // "Name": "VCAC-document.docx", // "ServerRelativeUrl": "/Documents/VCAC-document.docx", // "TimeCreated": "2016-03-04T12:38:01Z", // "TimeLastModified": "2017-01-16T04:44:31Z", // "Title": "", // "UIVersion": 3, // "UIVersionLabel": "0.3" // } // } // SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); } |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.