Sample code for 30+ languages & platforms
VBScript

Test Salesforce OAuth2 Access Token

See more Salesforce Examples

Demonstrates how to make a simple Salesforce REST API call to test a previously obtained access token.

Chilkat VBScript Downloads

VBScript
Dim fso, outFile
Set fso = CreateObject("Scripting.FileSystemObject")
'Create a Unicode (utf-16) output text file.
Set outFile = fso.CreateTextFile("output.txt", True, True)

success = 0

' This example does the following:

' curl -X GET https://yourInstance.salesforce.com/services/oauth2/userinfo \
'      -H "Authorization: Bearer YOUR_ACCESS_TOKEN"

set http = CreateObject("Chilkat.Http")

' Use the following online tool to generate HTTP code from a CURL command
' Convert a cURL Command to HTTP Source Code

' This example assumes the OAuth2 access token was previously fetched 
' and saved to a file.  See Get SalesForce OAuth2 Access Token via Authorization Flow

set json = CreateObject("Chilkat.JsonObject")
success = json.LoadFile("qa_data/tokens/_salesforce.json")
If (success = 0) Then
    outFile.WriteLine("Failed to load OAuth2 access token.")
    WScript.Quit
End If

' Here's an example of the JSON:

' {
'   "access_token": "00D41000....uLZBpT6",
'   "refresh_token": "5Aep....25xdGgkrV",
'   "signature": "cjTbSc5DvcKpaMoRTzuQTJLb1tcMw8LEO01flq4aMD4=",
'   "scope": "refresh_token id",
'   "instance_url": "https://d41000000f8a0eak-dev-ed.my.salesforce.com",
'   "id": "https://login.salesforce.com/id/00D41000000F8A0EAK/005410000....xAAE",
'   "token_type": "Bearer",
'   "issued_at": "1738348388166"
' }

' Adds the "Authorization: Bearer YOUR_ACCESS_TOKEN" header.
http.AuthToken = json.StringOf("access_token")

' We want to build the following URL:  https://<instance_id>.salesforce.com/services/oauth2/userinfo
set sbUrl = CreateObject("Chilkat.StringBuilder")
success = sbUrl.Append(json.StringOf("instance_url"))
success = sbUrl.Append("/services/oauth2/userinfo")

set sbResponseBody = CreateObject("Chilkat.StringBuilder")
success = http.QuickGetSb(sbUrl.GetAsString(),sbResponseBody)
If (success = 0) Then
    outFile.WriteLine(http.LastErrorText)
    WScript.Quit
End If

outFile.WriteLine("Response status code = " & http.LastStatus)

set jsonResponse = CreateObject("Chilkat.JsonObject")
success = jsonResponse.LoadSb(sbResponseBody)
jsonResponse.EmitCompact = 0
outFile.WriteLine(jsonResponse.Emit())

' The expected JSON response is something like this:

' {
'   "sub": "005xxxxxxxxxxxx",
'   "name": "John Doe",
'   "preferred_username": "johndoe@example.com",
'   "email": "johndoe@example.com",
'   "profile": "https://na85.salesforce.com/005xxxxxxxxxxxx"
' ...
' ...
' }

outFile.Close