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
(Excel) Automatically Refresh Token for 401 UnauthorizedDemonstrates how to automatically refresh an access token (without user interaction) when the token expires and a 401 Unauthorized response is received.
' This example requires the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. tokenFilePath = "qa_data/tokens/googleCalendar.json" ' Get our current access token. Dim jsonToken As Chilkat.JsonObject Set jsonToken = Chilkat.NewJsonObject success = jsonToken.LoadFile(tokenFilePath) If (jsonToken.HasMember("access_token") = False) Then Debug.Print "No access token found." Exit Sub End If Dim http As Chilkat.Http Set http = Chilkat.NewHttp http.AuthToken = jsonToken.StringOf("access_token") jsonResponse = http.QuickGetStr("https://www.googleapis.com/calendar/v3/users/me/calendarList") If (http.LastMethodSuccess <> True) Then If (http.LastStatus <> 401) Then Debug.Print http.LastErrorText Debug.Print "----" Debug.Print http.LastResponseBody Exit Sub End If ' The access token must've expired. ' Refresh the access token and then retry the request. Dim oauth2 As Chilkat.OAuth2 Set oauth2 = Chilkat.NewOAuth2 oauth2.TokenEndpoint = "https://www.googleapis.com/oauth2/v4/token" ' Replace these with actual values. oauth2.ClientId = "GOOGLE-CLIENT-ID" oauth2.ClientSecret = "GOOGLE-CLIENT-SECRET" ' Get the "refresh_token" oauth2.RefreshToken = jsonToken.StringOf("refresh_token") ' Send the HTTP POST to refresh the access token.. success = oauth2.RefreshAccessToken() If (success <> True) Then Debug.Print oauth2.LastErrorText Exit Sub End If ' The response contains a new access token, but we must keep ' our existing refresh token for when we need to refresh again in the future. success = jsonToken.UpdateString("access_token",oauth2.AccessToken) ' Save the new JSON access token response to a file. Dim sbJson As Chilkat.StringBuilder Set sbJson = Chilkat.NewStringBuilder jsonToken.EmitCompact = False success = jsonToken.EmitSb(sbJson) success = sbJson.WriteFile(tokenFilePath,"utf-8",False) Debug.Print "OAuth2 authorization granted!" Debug.Print "New Access Token = "; oauth2.AccessToken ' re-try the original request. http.AuthToken = oauth2.AccessToken jsonResponse = http.QuickGetStr("https://www.googleapis.com/calendar/v3/users/me/calendarList") If (http.LastMethodSuccess <> True) Then Debug.Print http.LastErrorText Exit Sub End If End If Debug.Print jsonResponse Debug.Print "-----------------------------" |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.