![]() |
Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Visual FoxPro) X.com App only authentication and OAuth 2.0 Bearer TokenSee more X ExamplesDemonstrates how to obtain an X.com 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. Your app will be able to, for example:
And it will not be able to:
Note: This example requires Chilkat v11.0.0 or greater. For more information, see https://docs.x.com/resources/fundamentals/authentication/oauth-2-0/application-only
LOCAL lnSuccess LOCAL lcConsumerKey LOCAL lcConsumerSecret LOCAL loHttp LOCAL loReq LOCAL loResp LOCAL loJson lnSuccess = 0 * It requires the Chilkat API to have been previously unlocked. * See Global Unlock Sample for sample code. * Update these values with your consumer key and secret (also known as API Key and API Key Secret). lcConsumerKey = "X_CONSUMER_KEY" lcConsumerSecret = "X_CONSUMER_SECRET" loHttp = CreateObject('Chilkat.Http') loHttp.BasicAuth = 1 loHttp.Login = lcConsumerKey loHttp.Password = lcConsumerSecret loReq = CreateObject('Chilkat.HttpRequest') loReq.AddParam("grant_type","client_credentials") loReq.HttpVerb = "POST" loReq.ContentType = "application/x-www-form-urlencoded" loResp = CreateObject('Chilkat.HttpResponse') lnSuccess = loHttp.HttpReq("https://api.x.com/oauth2/token",loReq,loResp) IF (lnSuccess = 0) THEN ? loHttp.LastErrorText RELEASE loHttp RELEASE loReq RELEASE loResp CANCEL ENDIF ? "Response Status Code: " + STR(loResp.StatusCode) IF (loResp.StatusCode <> 200) THEN ? "Expected a 200 response status code for success." ? loResp.BodyStr RELEASE loHttp RELEASE loReq RELEASE loResp CANCEL ENDIF * We should get a JSON response like this: * { * "token_type":"bearer", * "access_token":"..." * } loJson = CreateObject('Chilkat.JsonObject') loJson.Load(loResp.BodyStr) ? "Access token = " + loJson.StringOf("access_token") RELEASE loHttp RELEASE loReq RELEASE loResp RELEASE loJson |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.