Page 1 of 1
Fecha y Hora desde la Nube
Posted: Wed Dec 11, 2024 3:56 am
by JoseAlvarez
Hola a todos,
Necesito obtener la fecha y hora de mi pais (zona horaria Caracas-venezuela) desde la nube, de un servidor publico.
Alguna idea?
Le pregunte a la IA copilot, pero el codigo que me da arroja errores y confieso que no tengo conocimientos para corregirlo. Acá dejo el codigo
Code: Select all | Expand
PROCEDURE GetTimeCaracas()
local url, response, json, timeData
local url = "http://api.worldtimeapi.org/api/timezone/America/Caracas"
local HttpClient = NEW HttpClient()
response = HttpClient.GET(url)
IF response.status = 200 THEN
json = response.content
timeData = json["datetime"]
MESSAGEBOX("Fecha y Hora en Caracas:", timeData)
ELSE
MESSAGEBOX("Error al obtener la fecha y hora:", response.status)
ENDIF
ENDPROCEDURE
o quizás haya una manera de obtenerlo desde el mismo windows. Lo que se necesita es tener el valor de una fuente confable y no desde la misma PC en donde se ejecuta la aplicación, ya que puede ser cambiada con intencion del usuario o con el desgaste de la bateria del cmos.
Eso es lo que se quiere
evitar.
Puedo obtenerla con Mysql desde mi servidor de pago, pero no quiero "amarrar" al cliente con nada mío.
Agradezco la Ayuda
Re: Fecha y Hora desde la Nube
Posted: Wed Dec 11, 2024 4:22 am
by JoseAlvarez
Listo amigos, conseguí la solución acá mismo en el foro. Dejo el hilo, en la respuesta del master joao
https://forums.fivetechsupport.com/view ... =6&t=33555
Gracias a todos!
Gracias Master Joao
Re: Fecha y Hora desde la Nube
Posted: Thu Dec 12, 2024 12:19 pm
by karinha
GREAT my dear friend!
Regards, saludos.
Re: Fecha y Hora desde la Nube
Posted: Thu Dec 12, 2024 5:54 pm
by VitalJavier
Le dije a copilot que tenia varios errores
y termino en esto y funciono:
Code: Select all | Expand
function Ret_Date_Web()
LOCAL cGeoUrl := "http://ip-api.com/json/"
LOCAL cGeoResponse := HttpGet(cGeoUrl)
LOCAL cCity := ExtractField(cGeoResponse, "timezone")
LOCAL cUrl := "http://worldtimeapi.org/api/timezone/"+cCity
LOCAL cResponse := HttpGet(cUrl)
LOCAL cFecha, cHora, cDateTime
// Buscar el campo "datetime" en el JSON devuelto
cDateTime := ExtractField(cResponse, "datetime")
// Obtener fecha y hora
cFecha := SubStr(cDateTime, 1, 10) // Fecha en formato YYYY-MM-DD
cHora := SubStr(cDateTime, 12, 8) // Hora en formato HH:MM:SS
// Mostrar fecha y hora en un mensaje
MsgInfo("Fecha: " + cFecha + CRLF + "Hora: " + cHora, "Fecha y Hora de la Ciudad de México")
RETURN NIL
function HttpGet(cUrl)
LOCAL oHttp := CreateObject("Msxml2.XMLHTTP")
LOCAL cResponse
oHttp:Open("GET", cUrl, .F.)
oHttp:Send()
IF oHttp:Status = 200
cResponse := oHttp:ResponseText
ELSE
cResponse := ""
ENDIF
Release oHttp
RETURN cResponse
function ExtractField(cResponse, cField)
LOCAL nPos, nStart, nEnd, cValue
nPos = At('"' + cField + '":', cResponse)
IF nPos > 0
nStart = nPos + Len(cField) + 3
nEnd = At(',', cResponse, nStart) - 1
IF nEnd < 0
nEnd = At('}', cResponse, nStart) - 1
ENDIF
cValue = SubStr(cResponse, nStart, nEnd - nStart + 1)
cValue = StrTran(cValue, '"', '') // Eliminar comillas dobles
ELSE
cValue = ""
ENDIF
RETURN cValue
Re: Fecha y Hora desde la Nube
Posted: Fri Dec 13, 2024 1:18 pm
by karinha
Excelente Vital,
Code: Select all | Expand
#include "FiveWin.ch"
FUNCTION Main()
__SetCentury( "ON" )
Set( 4, if(__SetCentury(), "dd/mm/yyyy", "dd/mm/yy") )
Set( 207, "HH:MM:SS" )
Set( 5, YEAR( DATE() ) - 30 )
Ret_Date_Web()
RETURN NIL
FUNCTION Ret_Date_Web()
LOCAL WDIA, WMES, WANO, WFECHA
LOCAL cGeoUrl := "http://ip-api.com/json/"
LOCAL cGeoResponse := HttpGet( cGeoUrl )
LOCAL cCity := ExtractField( cGeoResponse, "timezone" )
LOCAL cUrl := "http://worldtimeapi.org/api/timezone/" + cCity
LOCAL cResponse := HttpGet( cUrl )
LOCAL cFecha, cHora, cDateTime
// Buscar el campo "datetime" en el JSON devuelto
cDateTime := ExtractField( cResponse, "datetime" )
// Obtener fecha y hora
cFecha := SubStr( cDateTime, 1, 10 ) // Fecha en formato YYYY-MM-DD
cHora := SubStr( cDateTime, 12, 8 ) // Hora en formato HH:MM:SS
WDIA := SUBST( cFecha, 9, 2 )
// ? WDIA
WMES := SUBST( cFecha, 6, 2 )
// ? WMES
WANO := SUBST( cFecha, 1, 4 )
// ? WANO
WFECHA := WDIA +"/"+ WMES +"/"+ WANO + " - " + cHora + " - " + ;
"Fecha y Hora de la Ciudad de México"
? WFECHA
/*
// Mostrar fecha y hora en un mensaje
MsgInfo( "Fecha: " + cFecha + CRLF + "Hora: " + cHora, ;
"Fecha y Hora de la Ciudad de México" )
*/
RETURN NIL
FUNCTION HttpGet( cUrl )
LOCAL oHttp := CreateObject( "Msxml2.XMLHTTP" )
LOCAL cResponse
oHttp:Open( "GET", cUrl, .F. )
oHttp:Send()
IF oHttp:STATUS = 200
cResponse := oHttp:ResponseText
ELSE
cResponse := ""
ENDIF
__MVXRelease( "oHttp" )
oHttp := NIL
RETURN( cResponse )
FUNCTION ExtractField( cResponse, cField )
LOCAL nPos, nStart, nEnd, cValue
nPos = At( '"' + cField + '":', cResponse )
IF nPos > 0
nStart = nPos + Len( cField ) + 3
nEnd = At( ',', cResponse, nStart ) - 1
IF nEnd < 0
nEnd = At( '}', cResponse, nStart ) - 1
ENDIF
cValue = SubStr( cResponse, nStart, nEnd - nStart + 1 )
cValue = StrTran( cValue, '"', '' ) // Eliminar comillas dobles
ELSE
cValue = ""
ENDIF
RETURN( cValue )
// FIN / END
Regards, saludos.
Re: Fecha y Hora desde la Nube
Posted: Fri Dec 13, 2024 4:55 pm
by JoseAlvarez
VitalJavier wrote:Le dije a copilot que tenia varios errores
y termino en esto y funciono:
Code: Select all | Expand
function Ret_Date_Web()
LOCAL cGeoUrl := "http://ip-api.com/json/"
LOCAL cGeoResponse := HttpGet(cGeoUrl)
LOCAL cCity := ExtractField(cGeoResponse, "timezone")
LOCAL cUrl := "http://worldtimeapi.org/api/timezone/"+cCity
LOCAL cResponse := HttpGet(cUrl)
LOCAL cFecha, cHora, cDateTime
// Buscar el campo "datetime" en el JSON devuelto
cDateTime := ExtractField(cResponse, "datetime")
// Obtener fecha y hora
cFecha := SubStr(cDateTime, 1, 10) // Fecha en formato YYYY-MM-DD
cHora := SubStr(cDateTime, 12, 8) // Hora en formato HH:MM:SS
// Mostrar fecha y hora en un mensaje
MsgInfo("Fecha: " + cFecha + CRLF + "Hora: " + cHora, "Fecha y Hora de la Ciudad de México")
RETURN NIL
function HttpGet(cUrl)
LOCAL oHttp := CreateObject("Msxml2.XMLHTTP")
LOCAL cResponse
oHttp:Open("GET", cUrl, .F.)
oHttp:Send()
IF oHttp:Status = 200
cResponse := oHttp:ResponseText
ELSE
cResponse := ""
ENDIF
Release oHttp
RETURN cResponse
function ExtractField(cResponse, cField)
LOCAL nPos, nStart, nEnd, cValue
nPos = At('"' + cField + '":', cResponse)
IF nPos > 0
nStart = nPos + Len(cField) + 3
nEnd = At(',', cResponse, nStart) - 1
IF nEnd < 0
nEnd = At('}', cResponse, nStart) - 1
ENDIF
cValue = SubStr(cResponse, nStart, nEnd - nStart + 1)
cValue = StrTran(cValue, '"', '') // Eliminar comillas dobles
ELSE
cValue = ""
ENDIF
RETURN cValue
En este foro no se termina de aprender nunca, ¡muy bien colega!