Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Unicode C) 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 <C_CkHttpW.h> #include <C_CkHttpRequestW.h> #include <C_CkHttpResponseW.h> #include <C_CkJsonObjectW.h> void ChilkatSample(void) { const wchar_t *consumerKey; const wchar_t *consumerSecret; HCkHttpW http; HCkHttpRequestW req; HCkHttpResponseW resp; HCkJsonObjectW json; // 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). consumerKey = L"TWITTER_CONSUMER_KEY"; consumerSecret = L"TWITTER_CONSUMER_SECRET"; http = CkHttpW_Create(); CkHttpW_putBasicAuth(http,TRUE); CkHttpW_putLogin(http,consumerKey); CkHttpW_putPassword(http,consumerSecret); req = CkHttpRequestW_Create(); CkHttpRequestW_AddParam(req,L"grant_type",L"client_credentials"); resp = CkHttpW_PostUrlEncoded(http,L"https://api.twitter.com/oauth2/token",req); if (CkHttpW_getLastMethodSuccess(http) != TRUE) { wprintf(L"%s\n",CkHttpW_lastErrorText(http)); CkHttpW_Dispose(http); CkHttpRequestW_Dispose(req); return; } wprintf(L"Response Status Code: %d\n",CkHttpResponseW_getStatusCode(resp)); if (CkHttpResponseW_getStatusCode(resp) != 200) { wprintf(L"Expected a 200 response status code for success.\n"); wprintf(L"%s\n",CkHttpResponseW_bodyStr(resp)); CkHttpW_Dispose(http); CkHttpRequestW_Dispose(req); return; } // We should get a JSON response like this: // { // "token_type":"bearer", // "access_token":"..." // } json = CkJsonObjectW_Create(); CkJsonObjectW_Load(json,CkHttpResponseW_bodyStr(resp)); wprintf(L"Access token = %s\n",CkJsonObjectW_stringOf(json,L"access_token")); CkHttpResponseW_Dispose(resp); CkHttpW_Dispose(http); CkHttpRequestW_Dispose(req); CkJsonObjectW_Dispose(json); } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.