Actualizar campos en pagina web desde un programa de visual basic

Iniciado por JOSE-CAMPOS, 6 Abril 2013, 05:38 AM

0 Miembros y 1 Visitante están viendo este tema.

JOSE-CAMPOS

Saludos he hecho algunos trabajos con electrónica para medir valores de sensores de temperatura, nivel, presion etc y los puedo ver en mi PC en tiempo real cada vez que cambia el valor de la lectura en el sensor cambia en la pantalla de la PC, y ahora lo que quiero y necesito es poder hacer una pagina web donde pueda mostrar esos mismos valores en tiempo real y que cuando se actualice el programa en visual, tenga la posibilidad de actualizar la pagina web tambien en tiempo real, solo necesito la forma de hacerlo ya que tengo un poco de conocimiento en VB6 y un poquito en HTML, espero haberme explicado bien, espero su ayuda, mil gracias
La accion mas cercana a la grandeza es la humildad

BlackM4ster

#1
Hola Jose espero poder ayudarte, si no sabes php, es jodido pero te paso un ejemplo:
Creamos un archivo .PHP que cuando le pasemos los valores los guarda en algun sitio (una base de datos no que sino te complicas jaja) puedes coger este Php de un ejemplo de Cookie Stealer:
recogerdatos.php
<?

$fecha=time();
$dato1 = $_GET['dato1'];
$dato2 = $_GET['dato2'];

$fff = fopen("temperaturas.txt","a"); //no es a+ porque queremos que se actualicen

$salida = "<br><table width='449' border='1' cellpadding='2' cellspacing='1' bordercolor='#000000' bgcolor='#FFFFFF'>
 <tr>
   <td width='137' rowspan='3'><div align='center'>$fecha</div></td>
 </tr>
 <tr>
   <td><div align='center'>$dato1</div></td>
 </tr>
 <tr>
   <td><div align='center'>$dato2</div></td>
 </tr>
</table>";

fwrite($fff, $salida);
fclose($fff);

echo "<script>location.href='www.google.es';</script>"; //Nos lleva a Google
?>


Desde tu programa, tendrás que acceder a la página web de la siguiente manera:
http://www.tupagina.com/recogerdatos.php?dato1=30&dato2=233

Puedes meter tantos datos como quieras. En vb6:
Option Explicit
Public Declare Function InternetOpen Lib "wininet.dll" Alias "InternetOpenA" (ByVal sAgent As String, ByVal lAccessType As Long, ByVal sProxyName As String, ByVal sProxyBypass As String, ByVal lFlags As Long) As Long
Public Declare Function InternetOpenUrl Lib "wininet.dll" Alias "InternetOpenUrlA" (ByVal hInternetSession As Long, ByVal sURL As String, ByVal sHeaders As String, ByVal lHeadersLength As Long, ByVal lFlags As Long, ByVal lContext As Long) As Long
Public Declare Function InternetReadFile Lib "wininet.dll" (ByVal hFile As Long, ByVal sBuffer As String, ByVal lNumBytesToRead As Long, lNumberOfBytesRead As Long) As Integer
Public Declare Function InternetCloseHandle Lib "wininet.dll" (ByVal hInet As Long) As Integer

Public Const IF_FROM_CACHE = &H1000000
Public Const IF_MAKE_PERSISTENT = &H2000000
Public Const IF_NO_CACHE_WRITE = &H4000000
   
Private Const BUFFER_LEN = 256


Public Function ActualizarDatos(dato1 As String, dato2 as string) as string
   Dim sBuffer As String * BUFFER_LEN, iResult As Integer, sData As String
   Dim hInternet As Long, hSession As Long, lReturn As Long

   'get the handle of the current internet connection
   hSession = InternetOpen("vb wininet", 1, vbNullString, vbNullString, 0)
   'get the handle of the url

   dim sURL as string
    sURL = "http://www.tupagina.com/recogerdatos.php?dato1="&dato1&"&dato2="&dato2

   If hSession Then hInternet = InternetOpenUrl(hSession, sURL, vbNullString, 0, IF_NO_CACHE_WRITE, 0)
   'if we have the handle, then start reading the web page
   If hInternet Then
       'get the first chunk & buffer it.
       iResult = InternetReadFile(hInternet, sBuffer, BUFFER_LEN, lReturn)
       sData = sBuffer
       'if there's more data then keep reading it into the buffer
       Do While lReturn <> 0
           iResult = InternetReadFile(hInternet, sBuffer, BUFFER_LEN, lReturn)
           sData = sData + Mid(sBuffer, 1, lReturn)
       Loop
   End If

   'close the URL
   GetUrlSource = sData
End Function


y en cualquier parte de tu código:
ActualizarDatos(500,36) //Por ejemplo

Con esto, la pagina guardará los últimos datos que le pases en el archivo de texto, que puede ser leido en otro php (iframe por ejemplo) asi:
<?php
readfile 
("http://www.tupagina.com/temperaturas.txt")
?>


Espero haberte ayudado  ;-)
- Pásate por mi web -
https://codeisc.com

JOSE-CAMPOS

#2
Saludos Black Master, estoy muy agradecido veo que eres bueno en esto y ademas debo confesar que me sorprende la voluntad de ayudar que tienes y las molestias que te tomaste al hacerlo, como dijiste si no se PHP, me sera cuesta arriba, sin embargo solo necesito saber como actualizar algunos campos en una pagina web, voy hacer honesto, no entendí mucho de lo que me enviaste pero ya mismo me pongo a meterle el pecho para familiarizarme y poder resolver lo que necesito, mil gracias nuevamente y estoy casi seguro que seguiré preguntándote al respecto, Saludos

PD: te iba a enviar una imagen pero no supe hacerlo por aca




Amigo Master, hice todo tal cual me indicas y no me corre, el archivo php lo subie a http://www.jose-campos.com/prueba/recogerdatos.php  pero al ejecutarlo en la web aparece en blanco pense dentro de mi ignorancia que apareceria  dos label con sus valores, obviamente hice algo o todo mal.

el formulario en visual debe llevar un control especial? algun boton? etc? mil gracias de antemano
La accion mas cercana a la grandeza es la humildad

BlackM4ster

#3
A ver, vamos por pasos  :rolleyes:

Las imagenes las puedes mandar subiendolas a http://imageshack.us por ejemplo y poniendo el enlace

El archivo que has subido no sirve, el codigo está mal puesto (cuando esté bien puesto, debería redirigirte a Google)
No quites la linea echo "<script>location.href='www.google.es';</script>"; //Nos lleva a Google que esa linea nos sirve para comprobar que el resto del código se ha ejecutado.

Al principio he pensado que tu servidor web no soportaba PHP pero luego, he visto que algún momento te funcionó y no te diste cuenta, cambiaste algo, y adiós  :laugh::
http://www.jose-campos.com/prueba/temperaturas.txt
Fijate que, aunque no le pusiste datos (.php?dato1=aosdnks&dato2=sdasd) al final de la url, la tabla si que te la guardó y eso es buena señal.
Te recomiendo que borres el codigo fuente entero de ese archivo, pongas el mio exactamente igual, accedas a tu url pasandole valores
http://www.jose-campos.com/prueba/recogerdatos.php?dato1=aosdnks&dato2=sdasd y consultes el archivo http://www.jose-campos.com/prueba/temperaturas.txt

Te falta por crear un archivo más, ver.php que sirve para ver las temperaturas
<?php
readfile 
("http://www.jose-campos.com/prueba/temperaturas.txt")
?>


Cuando hagas esto, avísame y miro a ver si funciona que entre semana tengo clases y no puedo estar en el ordenador
- Pásate por mi web -
https://codeisc.com

JOSE-CAMPOS

Saludos Master y gracias nuevamente:

ahora si va bien el código php, solo tuve que poner http:// antes de el link de google y en la linea 1 php despues del ?,  sin embargo pero aun no puedo actualizar los datos desde VB6 obviamente algo hice mal, lo hice de la siguiente manera

en un modulo puse esta parte

Option Explicit
Public Declare Function InternetOpen Lib "wininet.dll" Alias "InternetOpenA" (ByVal sAgent As String, ByVal lAccessType As Long, ByVal sProxyName As String, ByVal sProxyBypass As String, ByVal lFlags As Long) As Long
Public Declare Function InternetOpenUrl Lib "wininet.dll" Alias "InternetOpenUrlA" (ByVal hInternetSession As Long, ByVal sURL As String, ByVal sHeaders As String, ByVal lHeadersLength As Long, ByVal lFlags As Long, ByVal lContext As Long) As Long
Public Declare Function InternetReadFile Lib "wininet.dll" (ByVal hFile As Long, ByVal sBuffer As String, ByVal lNumBytesToRead As Long, lNumberOfBytesRead As Long) As Integer
Public Declare Function InternetCloseHandle Lib "wininet.dll" (ByVal hInet As Long) As Integer

Public Const IF_FROM_CACHE = &H1000000
Public Const IF_MAKE_PERSISTENT = &H2000000
Public Const IF_NO_CACHE_WRITE = &H4000000
     
Private Const BUFFER_LEN = 256

EN EL CODIGO DEL FORMULARIO COLOQUE ESTO

Public Function ActualizarDatos(dato1 As String, dato2 As String) As String
    Dim sBuffer As String * BUFFER_LEN, iResult As Integer, sData As String
    Dim hInternet As Long, hSession As Long, lReturn As Long

    'get the handle of the current internet connection
    hSession = InternetOpen("vb wininet", 1, vbNullString, vbNullString, 0)
    'get the handle of the url

    Dim sURL As String
 
    sURL = "http://www.jose-campos.com/prueba/recogerdatos.php?dato1=50&dato2=98"
   

    If hSession Then hInternet = InternetOpenUrl(hSession, sURL, vbNullString, 0, IF_NO_CACHE_WRITE, 0)
    'if we have the handle, then start reading the web page
    If hInternet Then
        'get the first chunk & buffer it.
        iResult = InternetReadFile(hInternet, sBuffer, BUFFER_LEN, lReturn)
        sData = sBuffer
        'if there's more data then keep reading it into the buffer
        Do While lReturn <> 0
            iResult = InternetReadFile(hInternet, sBuffer, BUFFER_LEN, lReturn)
            sData = sData + Mid(sBuffer, 1, lReturn)
        Loop
    End If

    'close the URL
    GetUrlSource = sData
End Function

ActualizarDatos = (500)  '''''OJO solo me corrio asi... porque de esta forma  no me funkaba ActualizarDatos (500,36)

otra pregunta esa numeracion que se genera en la parte central de la tabla en ver.php a que se refiere? mil gracias y de ti quedo atento
La accion mas cercana a la grandeza es la humildad

BlackM4ster

- Pásate por mi web -
https://codeisc.com

JOSE-CAMPOS

La accion mas cercana a la grandeza es la humildad

BlackM4ster

Pon exactamente esta funcion:

Public Function ActualizarDatos(dato1 As String, dato2 as string) as string
   Dim sBuffer As String * BUFFER_LEN, iResult As Integer, sData As String
   Dim hInternet As Long, hSession As Long, lReturn As Long

   'get the handle of the current internet connection
   hSession = InternetOpen("vb wininet", 1, vbNullString, vbNullString, 0)
   'get the handle of the url

   dim sURL as string
   sURL = "http://www.jose-campos.com/prueba/recogerdatos.php?dato1="&dato1&"&dato2="&dato2

   If hSession Then hInternet = InternetOpenUrl(hSession, sURL, vbNullString, 0, IF_NO_CACHE_WRITE, 0)
   'if we have the handle, then start reading the web page
   If hInternet Then
       'get the first chunk & buffer it.
       iResult = InternetReadFile(hInternet, sBuffer, BUFFER_LEN, lReturn)
       sData = sBuffer
       'if there's more data then keep reading it into the buffer
       Do While lReturn <> 0
           iResult = InternetReadFile(hInternet, sBuffer, BUFFER_LEN, lReturn)
           sData = sData + Mid(sBuffer, 1, lReturn)
       Loop
   End If

   'close the URL
   GetUrlSource = sData
End Function


y la llamas asi:
ActualizarDatos("500º","60º")
- Pásate por mi web -
https://codeisc.com

JOSE-CAMPOS

en que parte coloco esta linea?

ActualizarDatos("500º","60º")

Me disculpo por mi ignoracia
La accion mas cercana a la grandeza es la humildad

BlackM4ster

- Pásate por mi web -
https://codeisc.com