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) Twitter - Application Only AuthenticationDemonstrates how to get a Twitter OAuth2 token for application-only authentication. This allows you to issue authenticated requests on behalf of the application itself (as opposed to on behalf of a specific user). You don’t have the context of an authenticated user and this means that any request to API for endpoints that require user context, such as posting Tweets, will not work. However, the set of endpoints that will still be available can have a higher rate limit. Your app will be able to, for example:
And it will not be able to:
#include <CkHttp.h> #include <CkHttpRequest.h> #include <CkHttpResponse.h> #include <CkJsonObject.h> void ChilkatSample(void) { CkString strOut; // It requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // Note: Define your Twitter apps at https://apps.twitter.com/ // We're going to send an HTTPS POST that looks like this: // POST /oauth2/token HTTP/1.1 // Host: api.twitter.com // User-Agent: My Twitter App v1.0.23 // Authorization: Basic eHZ6MWV2RlM0d0VFUFRHRUZQSEJvZzpMOHFxOVBaeVJn // NmllS0dFS2hab2xHQzB2SldMdzhpRUo4OERSZHlPZw== // Content-Type: application/x-www-form-urlencoded;charset=UTF-8 // Content-Length: 29 // Accept-Encoding: gzip // // grant_type=client_credentials // Update these values with your consumer key and secret (also known as API key and API secret). const char *consumerKey = "TWITTER_CONSUMER_KEY"; const char *consumerSecret = "TWITTER_CONSUMER_SECRET"; CkHttp http; http.put_BasicAuth(true); http.put_Login(consumerKey); http.put_Password(consumerSecret); CkHttpRequest req; req.AddParam("grant_type","client_credentials"); CkHttpResponse *resp = http.PostUrlEncoded("https://api.twitter.com/oauth2/token",req); if (http.get_LastMethodSuccess() != true) { strOut.append(http.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } strOut.append("Response Status Code: "); strOut.appendInt(resp->get_StatusCode()); strOut.append("\r\n"); if (resp->get_StatusCode() != 200) { strOut.append("Expected a 200 response status code for success."); strOut.append("\r\n"); strOut.append(resp->bodyStr()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // We should get a JSON response like this: // { // "token_type":"bearer", // "access_token":"..." // } CkJsonObject json; json.Load(resp->bodyStr()); strOut.append("Access token = "); strOut.append(json.stringOf("access_token")); strOut.append("\r\n"); delete resp; SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); } |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.