Page 1 of 4

IP, Mac Address, Name desde mi modem

Posted: Tue Jun 18, 2024 8:05 pm
by FranciscoA
Hola Todos.
Existe alguna function en FiveWin o xHarbour que me devuelva listado o array de todos los dispositivos conectados al modem-router, que incluya ip, mac address, name?
Alguien que pueda compartir algun codigo?
Gracias de antemano.

Re: IP, Mac Address, Name desde mi modem

Posted: Wed Jun 19, 2024 12:57 am
by JoseAlvarez
+1

Re: IP, Mac Address, Name desde mi modem

Posted: Wed Jun 19, 2024 9:50 pm
by jrestojeda
Hola,
Yo hace muchos años había escrito esto:

https://forums.fivetechsupport.com/view ... ullnetview

Prueba a ver si te sirve.
Saludos,

Re: IP, Mac Address, Name desde mi modem

Posted: Wed Jun 19, 2024 11:36 pm
by FranciscoA
Gracias, Esteban.
El caso es que en ninguno de mis dos equipos con Windows 10 funciona el net view.
Saludos.

Re: IP, Mac Address, Name desde mi modem

Posted: Thu Jun 20, 2024 6:25 pm
by FranciscoA
Alguien mas?

Re: IP, Mac Address, Name desde mi modem

Posted: Sat Jun 22, 2024 4:46 am
by Jimmy
hi.

to get MACadress you can use WMI on each PC

this CODE use HMG Syntax, modify for Fivewin

Code: Select all | Expand

* #include "HMG.ch"
* REQUEST HB_GT_WIN_DEFAULT              // Console
// modify for Fivewin
#include "fivewin.ch"
#define SW_SHOW               5   
PROCEDURE Main

LOCAL a

   a := showNet()
   
   MEMOWRIT( "Info.TXT", a)
// modify for Fivewin
   ShellExecute(GetActiveWindow(), "open", "Info.TXT",,, SW_SHOW )
*   _Execute ( GetActiveWindow() , , "Info.TXT", , , 5 )
RETURN

FUNCTION showNet()
LOCAL oWmi, oBoard
LOCAL bError := ERRORBLOCK( { | oErr | BREAK( oErr ) } )
LOCAL cInfo := REPLICATE( "-", 80 ) + CRLF

   oWmi := WmiService()
   BEGIN SEQUENCE
      cInfo += "netIP" + CRLF
      FOR EACH oBoard IN oWmi:ExecQuery( "SELECT * FROM Win32_NetworkAdapterConfiguration" )
         cInfo += "Description : " + VAR2CHAR(oBoard:Description) + CRLF
         cInfo += "MACAddress  : " + VAR2CHAR(oBoard:MACAddress ) + CRLF
         cInfo += "IPAddress   : " + VAR2CHAR(oBoard:IPAddress  ) + CRLF
         cInfo += REPLICATE( "-", 80 ) + CRLF
      NEXT
   END SEQUENCE
   ERRORBLOCK( bError )

RETURN cInfo

STATIC FUNCTION VAR2CHAR( cIn )
LOCAL cOut := hb_valToExp( cIn )
RETURN STRTRAN( cOut, '"', '' )

STATIC FUNCTION WMIService()
STATIC oWMI
LOCAL oLocator

   IF oWMI == NIL
      oLocator := CreateObject( "wbemScripting.SwbemLocator" )
      oWMI := oLocator:ConnectServer()
   ENDIF

RETURN oWMI

*+ EOF: 
 

Re: IP, Mac Address, Name desde mi modem

Posted: Sat Jun 22, 2024 2:29 pm
by Danielmaximiliano
Hola Jimmy:
Francisco necesita saber las IP con sus datos "Nombre de PC" y "Direccion MAC"
el comando "Net View" no funciona en windows 10 y 11 ya que pertenece a el protocolo SMB 1.0 que Microsoft recomienda no usar pero es posible usar activando 3 servicios en windows.
Net View nos da el nombre
nbtstat /A {direccion} nos da la direccion MAC (tampoco funciona en W10-11)
se deberia usar un poco de C y crear una libreria , ejemplos opensource hay varios y el que me gusto es Angry IP Scanner pero esta diseñado en java pero su interfaz es simple y intuitiva.
SLDS

Re: IP, Mac Address, Name desde mi modem

Posted: Sat Jun 22, 2024 6:36 pm
by FranciscoA
Gracias Jimmy.
Desafortunadamente desconozco HMG.

Sin embargo hice prueba con WMI como lo he hecho anteriormente con otros comandos, y los resultados no son los que esperaba.

elseif nOption == 7
oQry := oWMI:ExecQuery( "SELECT * FROM Win32_NetworkAdapterConfiguration" )
aTitCols:= {"Caption", "Description","MacAddress","IpAddress"}
for each oPC in oQry
aadd( aInfo,{ oPC:Caption, oPC:Description, oPC:MacAddress, oPC:IpAddress } )
next

Re: IP, Mac Address, Name desde mi modem

Posted: Sat Jun 22, 2024 6:42 pm
by FranciscoA
Daniel, gracias por contestar.

Voy a hecharle un vistaso a Angry IP scaner a ver que consigo.

La informacion podria sacarla del administrador del modem, pero no encuentro como enviar la info a un .txt, ademas que éste tampoco identifica los nombres de todos los dipositivos conectados a la red wifi (ejemplo tablets )

Saludos.

Re: IP, Mac Address, Name desde mi modem

Posted: Sat Jun 22, 2024 7:23 pm
by Danielmaximiliano
FranciscoA wrote:Daniel, gracias por contestar.

Voy a hecharle un vistaso a Angry IP scaner a ver que consigo.

La informacion podria sacarla del administrador del modem, pero no encuentro como enviar la info a un .txt, ademas que éste tampoco identifica los nombres de todos los dipositivos conectados a la red wifi (ejemplo tablets )

Saludos.
Uso Fing para escritorio o Fing para android.
También estoy fijando me sobre librerías de descubrimiento de dispositivos IP .. hay una disponible pero no tengo instalado visual 15 para poder compilar con Make de mingw

Re: IP, Mac Address, Name desde mi modem

Posted: Sat Jun 22, 2024 8:11 pm
by Willi Quintana
Estimado, echale un ojo a esto:

Code: Select all | Expand

#include "FiveWin.ch"

Function WMainInfo()
LOCAL  oDatos, oSrv, oJob, i
LOCAL    nFree:= ""
LOCAL     oLoc:= CreateObject( "wbemScripting.SwbemLocator" )
LOCAL   objWMI:= oLoc:ConnectServer()

LOCAL oSistema:= objWMI:ExecQuery("Select * from Win32_PhysicalMedia")
LOCAL   oDisco:= objWMI:ExecQuery("Select * from Win32_LogicalDisk")
LOCAL   oParti:= objWMI:ExecQuery("Select * from CIM_DiskPartition")
LOCAL  oDisket:= objWMI:ExecQuery("Select * From Win32_LogicalDisk Where DeviceID = 'A:'")
LOCAL   objUnd:= objWMI:ExecQuery("Select * from Win32_MappedLogicalDisk")
LOCAL     oUnd:= objWMI:ExecQuery("Select * from Win32_CDROMDrive")
LOCAL  oResolu:= objWMI:ExecQuery("Select * from Win32_DesktopMonitor")
LOCAL  oSistem:= objWMI:ExecQuery("Select * from Win32_OperatingSystem")
LOCAL   oUsers:= objWMI:ExecQuery("Select * from Win32_Account")
LOCAL    oServ:= objWMI:ExecQuery("Select * from Win32_Service Where Name = 'Themes'")
LOCAL    oTime:= objWMI:ExecQuery("Select * from Win32_LocalTime")
LOCAL    oProc:= objWMI:ExecQuery("Select * from Win32_Processor")
LOCAL     oJbs:= objWMI:ExecQuery("SELECT Product, SerialNumber FROM Win32_BaseBoard")
LOCAL   oIpSet:= objWMI:ExecQuery("SELECT IPAddress FROM Win32_NetworkAdapterConfiguration WHERE IPEnabled=TRUE")
LOCAL   oList := objWMI:ExecQuery("Select * from Win32_ComputerSystem")

//Return(Nil)
objWMI:= oLoc:ConnectServer()
oJbs := objWMI:ExecQuery( "select * from Win32_BaseBoard" )
//oSrv:ExecQuery( "SELECT * FROM Win32_BaseBoard" )


FOR Each oDatos In oSistema
    MsgInfo("Serial de fabrica: " + ALLTRIM(cValToChar(oDatos:SerialNumber)),"Numero de serie del disco duro")
NEXT



FOR Each oDatos In oDisco
    MsgInfo("Unidad: " + ALLTRIM(cValToChar(oDatos:Name)) + "\  Serial: " + ALLTRIM(cValToChar(oDatos:VolumeSerialNumber)),"Unidad y serial lógico de las unidades de disco")
NEXT



FOR Each oDatos in oParti
    MsgInfo(ALLTRIM(cValToChar(oDatos:Name)) + " - Tamaño: " +ALLTRIM(cValToChar(oDatos:Size)) + " En: " + ALLTRIM(cValToChar(oDatos:SystemName)) + " - Tipo: " + ALLTRIM(cValToChar(oDatos:TYPE)),"Particiones disponibles")
NEXT



FOR Each oDatos in oDisket
    nFree:= oDatos:FreeSpace

   IF VALTYPE(nFree) = "U"
         MsgInfo("No hay diskete en la unidad A:\","Aviso del WMI de Windows")
   ELSE
         MsgStop("Hay un diskete en la unidad A:\","Aviso del WMI de Windows")
   ENDIF

NEXT



FOR Each oDatos In objUnd
    MsgInfo("Device ID: " + oDatos:DeviceID +" Nombre: " + oDatos:Name +" Espacio Libre: " + cValtoChar(oDatos:FreeSpace) + " Tamaño: " + cValtoChar(oDatos:Size),"Lista de unidades Mapeadas en Mi PC")
NEXT



FOR Each oDatos in oUnd
    MsgInfo("Unidad: " + oDatos:Drive + " " + "Nombre: " + oDatos:Caption,"Unidades de CD instaladas en el equipo")
NEXT



FOR Each oDatos in oResolu
   MsgInfo("Trabajando a Resolución de Alto: " + cValToChar(oDatos:ScreenHeight) + "  y Ancho: " + cValToChar(oDatos:ScreenWidth),"Resolucion de Panralla")
NEXT



FOR Each oDatos In oSistem
    MsgInfo(oDatos:InstallDate,"Fecha de Instalación de Windows XP")
NEXT



FOR Each oDatos in oSistem
    MsgInfo("Directorio de Windows es: " + oDatos:WindowsDirectory +"  Directorio del Sistema es: "+ oDatos:SystemDirectory,"Directorio de Windows y del Sistema")
NEXT


/*
FOR Each oDatos in oUsers
    MsgInfo(cValToChar(oDatos:Name) + " - " + cValToChar(oDatos:Caption),"Lista de Usuarios de Windows")
NEXT



MsgInfo("Deshabilitarndo los Themes en Windows XP")
FOR Each oDatos in oServ
    oDatos:StopService()
    SysRefresh()
NEXT



MsgInfo("Habilitando los Themes en Windows XP")
FOR Each oDatos in oServ
    oDatos:StartService()
    SysRefresh()
NEXT

*/

FOR Each oDatos in oSistem
    MsgInfo(oDatos:Caption + " " + oDatos:VERSION,"Sistemas operativos instalados en el PC")
NEXT



FOR Each oDatos in oTime
     MsgInfo( "Día: " + cValToChar(oDatos:DAY) + CRLF +;
              "Día de la semana: " + cValToChar(oDatos:DayOfWeek) + CRLF +;
              "Hora: " + cValToChar(oDatos:Hour) + CRLF +;
              "Minutos: " + cValToChar(oDatos:Minute) + CRLF +;
              "Mes: " + cValToChar(oDatos:MONTH) + CRLF +;
              "Segundos: " + cValToChar(oDatos:Second) + CRLF +;
              "Semana en el mes: " + cValToChar(oDatos:WeekInMonth) + CRLF +;
              "Año: " + cValToChar(oDatos:YEAR),"Dia, Hora, Mes y Año desde WMI")
NEXT


FOR EACH oDatos IN oProc
        MsgInfo("El Nombre del Procesador es: "+Alltrim(cValtoChar(oDatos:Name)),"Desde WMI")
        MsgInfo("la Velocidad Actual del Procesador es: "+Alltrim(cValtoChar(oDatos:CurrentClockSpeed)) + " Mghz","Desde WMI")
        MsgInfo("la Velocidad Màxima del Procesador es: "+Alltrim(cValtoChar(oDatos:MaxClockSpeed)) + " Mghz","Desde WMI")

NEXT


FOR EACH oDatos IN oJbs
        MsgInfo("El Tipo de la MotherBoard es: "+Alltrim(cValtoChar(oDatos:Product)),"Desde WMI")
        MsgInfo("El Número de Serie de la MotherBoard es: "+Alltrim(cValtoChar(oDatos:SerialNumber)),"Desde WMI")
NEXT

FOR EACH oDatos IN oIPSet
  MsgInfo("El IPAddress es: "  + Alltrim(cValtoChar(oDatos:IPAddress(0))), "Desde WMI")
  MsgInfo("El MacAddress es: "  + Alltrim(cValtoChar(oDatos:IPAddress(1))), "Desde WMI")
NEXT

FOR EACH oDatos IN oList
    If oDatos:PartOfDomain
       MsgInfo("Dominio: " + oDatos:Domain, "Desde WMI")
      Else
       MsgInfo("Grupo de Trabajo: " + oDatos:Domain, "Desde WMI")
    EndIf
Next

Return nil


Re: IP, Mac Address, Name desde mi modem

Posted: Sat Jun 22, 2024 9:53 pm
by cmsoft
Francisco, se que no es exactamente lo que estas buscando, pero tal vez pueda ser una convinacion del comando ARP con otros

Te dejo algo que estuve probando para este caso, es algo simple, pero es una punta

Code: Select all | Expand

#include "FiveWin.ch"
FUNCTION Main()
    LOCAL aData, cOutput

    // Ejecuta el comando ARP para obtener la tabla ARP
    memowrit( 'ips.bat', "arp -a > ips.txt" )
    WaitRun( 'ips.bat' , 0 )     
    cOutput := MemoRead(".\ips.txt")
    aData := hb_ATokens(cOutput, chr(10))
    xbrowse(aData)
 
RETURN NIL

Re: IP, Mac Address, Name desde mi modem

Posted: Sat Jun 22, 2024 10:46 pm
by FranciscoA
Willi, muchas gracias.
FOR EACH oDatos IN oIPSet
MsgInfo("El IPAddress es: " + Alltrim(cValtoChar(oDatos:IPAddress(0))), "Desde WMI")
MsgInfo("El MacAddress es: " + Alltrim(cValtoChar(oDatos:IPAddress(1))), "Desde WMI")
NEXT
El codigo funciona, pero... siempre los peros... el resultado es del equipo local. La IP está ok, pero la MAC es diferente a la que muestra arp -a.

Saludos.

Re: IP, Mac Address, Name desde mi modem

Posted: Sat Jun 22, 2024 10:49 pm
by FranciscoA
Hola César.
Precisamente hasta ahí he llegado, usando arp -a

Muchas gracias.

Re: IP, Mac Address, Name desde mi modem

Posted: Sat Jun 22, 2024 10:56 pm
by cmsoft
Francisco
Aca usando un poco de una pagina que te indica cual es el fabricante del dispositivo, tal vez te sirva un poco mas

Code: Select all | Expand

#include "FiveWin.ch"

FUNCTION Main()
    LOCAL oWnd, oBrw, aData, cOutput

    // Ejecuta el comando ARP para obtener la tabla ARP
    memowrit( 'ips.bat', "arp -a > ips.txt" )
    WaitRun( 'ips.bat' , 0 )     
    cOutput := MemoRead(".\ips.txt")
    aData := hb_ATokens(cOutput, chr(10))    
    ADEL(aData,1)
    ADEL(aData,1)
    ADEL(aData,1)
    aData := Separar(aData)
    aData := Verifica(aData)
    xbrowse(aData)
RETURN NIL

STATIC FUNCTION Separar(aData)
LOCAL aData1 := {},  aData2 := {}, cText, i, j := 1
FOR i := 1 TO LEN(aData)
    cText := aData[i]    
    if !empty(cText)        
        AADD(aData1,{ALLTRIM(LEFT(cText,17)),ALLTRIM(SUBSTR(cText,18,25)),ALLTRIM(RIGHT(cText,12))})
    endif    
NEXT i 
FOR i := 1 TO LEN(aData1)
    IF( aData1[i,1] > '192' .OR. aData1[i,2] = 'ff-ff-ff-ff-ff-ff')
       LOOP
    ENDIF
    AADD(aData2,{aData1[i,1],aData1[i,2],aData1[i,3],'https://aruljohn.com/mac/'+STRTRAN(aData1[i,2],'-','')})
NEXT i 
RETURN aData2     

STATIC FUNCTION Verifica(aData)
LOCAL cText, i , cResult
FOR i := 1 TO LEN(aData)
    cText := WebPageContents(ALLTRIM(aData[i,4]))
    cResult := SUBSTR(cText,At('<tr><td>Vendor</td><td><span id="vdr14999879">',cText)+46,200 )    
    cResult := LEFT(cResult,At('</span>',cResult)-1)
    aData[i,4] := cResult 
NEXT i    
RETURN aData
 
Esta medio poco eficiente el codigo, pero en mi caso me funciono con los dispostivos que tengo conectados en casa
Image
Es muy parecido a lo que me da el producto IP Scanner
Image
Creo que lo que no me da es mi PC, porque hago el ipconfig y yo tengo la ip que falta
El lunes puedo probar en el trabajo a ver que me tira
Espero que al menos te de una punta
Saludos