Tech Articles


ALTERNATIVA PARA CONSUMIR WEB SERVICES REST JSON VERSIONES ANTERIORES (6.5, … , 11.5)


Con los nuevos sistemas una de las cosas que hoy en día escuchamos es: tenemos un web services donde puedes consultar…

Por lo que ante esta necesidad y teniendo un sistema desarrollado originalmente en powerbuilder 6.5 ( les traigo esta solución.

Un “consumer” de WS REST

Para hacer este ejemplo utilizaremos objetos no visuales, principalmente el objeto internetresult.

1.-  Creamos un objeto heredado de internetresult (Estandard Class) al cual llamaremos: nvo_internet_result.

2.- Declaramos la siguiente variable de instancia

window  lw_child //Handle

 

3.- Agregamos una función la cual llamaremos of_set_window en el objeto  nvo internet_result.

  • Recibe argumento de tipo Window (Handle)

  • Retorna un Entero

4.- Agregamos código a una función la cual debe llamarse internetdata

  • Recibe argumento de tipo blob

  • Retorna un Entero

5.-  Creamos un objeto no visual custom (Custom Class) al cual llamaremos: nvo_cws

6.- Declaramos las siguientes variables de instancia

string is_authorization

string is_endpoint

Inet  iinet_base

nvo_internet_result iir_msgbox  // El objeto creado anteriormente

string is_request

window iw_window   //Handle

 

7.- Agregamos una función la cual llamaremos of_set_endpoint.

  • Recibe argumento de tipo String

  • Retorna un Entero

8.- Agregamos una función la cual llamaremos of_set_window en el objeto cws.

  • Recibe argumento de tipo Window (Handle)

  • Retorna un Entero

 

9.- Agregamos una función la cual llamaremos of_exec en el objeto nvo_cws.

 

10.- Una vez realizadas las acciones anteriores procedemos a crear la interface gráfica.

  1. Agregamos un objeto window a nuestra aplicación con los siguientes objetos:

    1. Single line edit al cual llamaremos: sle_resource, ahí pondremos donde esta nuestro recurso.

    2. Multiline edit al cual llamaremos: mle_1

    3. CommmandButton al cual llamaremos: cb_test

    4. Y finalmente un datawindowsal cual llamaremos: dw_ws, su dataobject será un datawindow tipo external con dos campos tipo string

11.- Procedemos a poner el código en nuestra window

Agregamos el siguiente código en el evento open

obj_cws = CREATE nvo_cws

12.- Agregamos la función of_respuesta  la cual es llamada dinámicamente .

13.- Finalmente ponemos el siguiente código en el evento clicked del botón

 

Imágenes de apoyo

Aunque nuestro web service rest puede producir  json y xml por default genera el json

 

 

GlassFish 5 con el 4.1.1 generaba diversas excepciones

 

Definición del datawindow external

Comments (2)
Monday, Jun 04 2018

where it comesthe object  lib_json.

I get an error trying to create the visual interfase:

Error C0001 Illegal data type: lib_json

Undefined variable: json

Please help where I should do corrections to the example code 

 

#5
0

Monday, Jun 04 2018

Hi,

You can comment this lines
//lib_Json...
//json..

With this you should retrieve since Web service

The lines commented above is for parse, and show in datawindow

#6
0

Find Articles by Tag

Icon Event Handling Elevate Conference IDE Automated Testing Service CI/CD Jenkins SVN GhostScript Encoding COM Database Table Sort Messagging Bug iOS PBDOM Script Debugging DevOps PFC Transaction Event Handler Filter Graph DataWindow Database Debug Import UI Themes Interface RibbonBar Builder Export JSONGenerator OrcaScript C# Database Connection TreeView Trial NativePDF WinAPI ODBC Git Data OAuth 2.0 Debugger Azure PBVM TLS/SSL PowerServer Web Source Control Class TortoiseGit RichTextEdit Control Web API Model WebBrowser API Syntax Error Resize .NET Std Framework HTTPClient Database Painter Window Database Table Schema Windows 10 Icons Performance PostgreSQL External Functions Migration Android XML ActiveX Menu Database Object DataWindow JSON PDF CoderObject Oracle Outlook DataType Configuration License Encryption PBNI SnapDevelop 32-bit PowerBuilder Compiler Linux OS RESTClient Excel Branch & Merge PowerScript (PS) File Validation Visual Studio UI Modernization SQL DragDrop Charts Repository Open Source SnapObjects SqlModelMapper Application MessageBox PowerBuilder SDK Installation RibbonBar Import JSON Platform .NET DataStore Stored Procedure Web Service Proxy Source Code Authentication Testing PDFlib CrypterObject .NET Assembly JSON PowerServer Mobile UI Text Event Database Profile Export JSON SqlExecutor Array Authorization JSONParser OAuth Windows OS PostgreSQL ODBC driver Database Table Data TFS Mobile Variable PowerBuilder (Appeon) SOAP Design InfoMaker Deployment REST BLOB DLL 64-bit OLE SQL Server Expression