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
(VB.NET UWP/WinRT) hacienda.go.cr Obtener TokenGets an access token using the Resource Owner Password Credential Grant for the Recepción de Comprobantes Electrónicos del Ministerio de Hacienda (Costa Rica) For more information, see https://www.hacienda.go.cr/ATV/ComprobanteElectronico/docs/esquemas/2016/v4.3/Guia_IdP.pdf
' This example assumes the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. Dim http As New Chilkat.Http Dim success As Boolean ' Implements the following CURL command: ' curl -X "POST" "https://idp.comprobanteselectronicos.go.cr/auth/realms/rut-stag/protocol/openid-connect/token" \ ' -H "Content-Type: application/x-www-form-urlencoded; charset=utf-8" \ ' --data-urlencode "client_id=api-stag" \ ' --data-urlencode "username=cpj-3-101-261506@stag.comprobanteselectronicos.go.cr" \ ' --data-urlencode "password=my_password" \ ' --data-urlencode "grant_type=password" ' Use the following online tool to generate HTTP code from a CURL command ' Convert a cURL Command to HTTP Source Code Dim req As New Chilkat.HttpRequest req.HttpVerb = "POST" req.Path = "/auth/realms/rut-stag/protocol/openid-connect/token" req.ContentType = "application/x-www-form-urlencoded" req.AddParam("client_id","api-stag") req.AddParam("username","cpj-3-101-261506@stag.comprobanteselectronicos.go.cr") req.AddParam("password","my_password") req.AddParam("grant_type","password") Dim resp As Chilkat.HttpResponse = Await http.PostUrlEncodedAsync("https://idp.comprobanteselectronicos.go.cr/auth/realms/rut-stag/protocol/openid-connect/token",req) If (http.LastMethodSuccess = False) Then Debug.WriteLine(http.LastErrorText) Exit Sub End If Dim sbResponseBody As New Chilkat.StringBuilder resp.GetBodySb(sbResponseBody) Dim jResp As New Chilkat.JsonObject jResp.LoadSb(sbResponseBody) jResp.EmitCompact = False Debug.WriteLine("Response Body:") Debug.WriteLine(jResp.Emit()) Dim respStatusCode As Integer = resp.StatusCode Debug.WriteLine("Response Status Code = " & respStatusCode) If (respStatusCode >= 400) Then Debug.WriteLine("Response Header:") Debug.WriteLine(resp.Header) Debug.WriteLine("Failed.") Exit Sub End If ' Sample JSON response: ' (Sample code for parsing the JSON response is shown below) ' { ' "access_token": "ey....", ' "expires_in": 300, ' "id_token": "ey....", ' "not-before-policy": 0, ' "refresh_expires_in": 1800, ' "refresh_token": "ey...", ' "session_state": "...", ' "token_type": "bearer" ' } ' Sample code for parsing the JSON response... ' Use the following online tool to generate parsing code from sample JSON: ' Generate Parsing Code from JSON Dim access_token As String = jResp.StringOf("access_token") Dim expires_in As Integer = jResp.IntOf("expires_in") Dim id_token As String = jResp.StringOf("id_token") Dim not_before_policy As Integer = jResp.IntOf("not-before-policy") Dim refresh_expires_in As Integer = jResp.IntOf("refresh_expires_in") Dim refresh_token As String = jResp.StringOf("refresh_token") Dim session_state As String = jResp.StringOf("session_state") Dim token_type As String = jResp.StringOf("token_type") ' Save the JSON to a file for future requests. Dim fac As New Chilkat.FileAccess fac.WriteEntireTextFile("qa_data/tokens/hacienda_cr.json",jResp.Emit(),"utf-8",False) |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.