Autor
|
Tema: ¿Como monitorizar unidades de dispositivos PENDRIVE? (Leído 4,676 veces)
|
Eleкtro
Ex-Staff
Desconectado
Mensajes: 9.878
|
Bueno, llevo tiempo intentando hacer una aplicación para monitorizar pendrives (en modo oculto) y copiar todos los datos A OTRO PENDRIVESólo tengo hecha un poco la interfaz y cuatro tonterías más. PD: Es un WPF, por si tiene importancia. Para avanzar en la aplicación, necesito información sobre: - como monitorizar las unidades que se conectan al PC (Tando su inserción como su extracción)
- saber si el mismo método de monitorización serviría para Win XP / VISTA / 7 (si se tuviera que monitorizar con APIs...)
- como saber si la unidad conectada se trata de un pendrive
- como obtener la letra del pendrive conectado, la etiqueta (nombre/label), entre otros datos útiles que se puedan obtener sobre el dispositivo conectado.
PD: Imagino que para lo penúltimo y último podría usar WMI, ¿NO?, no sé si quizás habrá algo más sencillo/rápido/eficaz... Y por último, para este proyecto necesito una ayudita en este post: Como aplicar cambios al registro y refrescar el sistema sin tener que reiniciar?Gracias por leer.
|
|
« Última modificación: 1 Febrero 2013, 23:56 pm por EleKtro H@cker »
|
En línea
|
|
|
|
Keyen Night
Desconectado
Mensajes: 496
Nothing
|
Para la detección de medios extraibles, puedes interceptar los mensajes de Windows, que indican cambio de hardware, tengo código hecho pero no te lo voy a dar, para ver si te empezamos a acostumbrar a investigar. Te dejo algunas pistas: Protected Overrides Sub WndProc(ByRef [Message] As Message) End Sub Public Enum ConstWindowsDrivers As Integer Change = &H219 Arrival = &H8000 QueryRemove = &H8001 QueryRemoveFailed = &H8002 RemovePending = &H8003 RemoveComplete = &H8004 TypeVolume = &H2 End Enum
Es aun más fácil de lo que piensas
|
|
« Última modificación: 5 Febrero 2013, 01:19 am por Keyen Night »
|
En línea
|
La Fé Mueve Montañas... ...De Dinero
La programación es más que un trabajo es más que un hobby es una pasión...
|
|
|
Eleкtro
Ex-Staff
Desconectado
Mensajes: 9.878
|
Keyen, muchas gracias por la info, a pesar de que ahora pienses que soy un vago quizás por culpa de lo que siempre anda comentando spiritdead... a mi cualquier información que me den me sirve para empezar, y no te preocupes que buscaré.
Me dejas bastante perdido porque yo siempre he usado la API de windows para realizar funciones y cambios, sin necesidad de hacer gran cosa, pero no para recibir/interceptar/monitorizar datos, y no sé si será tán fácil como almacenarlo en una variable cada cierto tiempo para comprobar el valor del resultado y ya está, pero bueno, ya lo busco.
Saludos
|
|
|
En línea
|
|
|
|
Eleкtro
Ex-Staff
Desconectado
Mensajes: 9.878
|
Muchas gracias al moderador invisible por reabrir el post
Ya he encontrado como monitorizar la inserción-extracción de los dispositivos con los WindowsMessages usando la API, pero primero me he puesto a hacer otra función que necesito, he sacado la idea de aquí: [APORTE] Interceptar Archivos/Directorios USB(Gracias Kubox) En la función necesito hacer demasiadas comprobaciones, muchos "IF", ¿Tienen alguna idea para reducir/mejorar este código?: PD: El problema que tengo es que tengo que hacer las mismas comprobaciones para "ALL", y las mismas comprobaciones para el resto de la enumeración, no sé como hacerlo más simple. Private Enum DriveType ALL CDRom = IO.DriveType.CDRom Fixed = IO.DriveType.Fixed Network = IO.DriveType.Network Ram = IO.DriveType.Ram Removable = IO.DriveType.Removable Unknown = IO.DriveType.Unknown End Enum Private Function Get_Drives_Info( _ ByVal DriveType As DriveType, _ ByVal Name As Boolean, _ Optional ByVal Label As Boolean = False, _ Optional ByVal Type As Boolean = False, _ Optional ByVal Format As Boolean = False, _ Optional ByVal Size As Boolean = False, _ Optional ByVal FreeSpace As Boolean = False) As List(Of String) Dim Drive_Info_List As New List(Of String) Dim Drive_Info As String = Nothing For Each Drive In Microsoft. VisualBasic. FileIO. FileSystem. Drives If DriveType = DriveType.ALL Then If Drive. IsReady = True Then If Name Then Drive_Info += Drive. Name & ";" If Label Then Drive_Info += Drive. VolumeLabel & ";" If Type Then Drive_Info += Drive. DriveType. ToString & ";" If Format Then Drive_Info += Drive. DriveFormat & ";" If Size Then Drive_Info += Drive. TotalSize. ToString & ";" If FreeSpace Then Drive_Info += Drive. TotalFreeSpace & ";" End If Else If Drive. IsReady = True And Drive. DriveType = DriveType Then If Drive. IsReady = True Then If Name Then Drive_Info += Drive. Name & ";" If Label Then Drive_Info += Drive. VolumeLabel & ";" If Type Then Drive_Info += Drive. DriveType. ToString & ";" If Format Then Drive_Info += Drive. DriveFormat & ";" If Size Then Drive_Info += Drive. TotalSize. ToString & ";" If FreeSpace Then Drive_Info += Drive. TotalFreeSpace & ";" End If End If End If If Drive_Info IsNot Nothing Then Drive_Info_List.Add(Drive_Info) : Drive_Info = Nothing Next Return Drive_Info_List End Function
saludos
|
|
« Última modificación: 6 Febrero 2013, 03:42 am por EleKtro H@cker »
|
En línea
|
|
|
|
|
Eleкtro
Ex-Staff
Desconectado
Mensajes: 9.878
|
select case
Gracias, pero no creo que un select case me vaya a solucionar el problema: select case blablabla case DriveType.ALL if name then... if label then... if size then... if type then... if freespace then... if format then... case else if name then... if label then... if size then... if type then... if freespace then... if format then... end case Lo que quiero es NO tener que repetir las comprobaciones para los dos casos, me gustaría simplificarlo de alguna manera, y para eso necesito ejemplos please!. saludos
|
|
« Última modificación: 6 Febrero 2013, 09:37 am por EleKtro H@cker »
|
En línea
|
|
|
|
HdM
Desconectado
Mensajes: 1.674
|
Hola. Igual estoy interpretando mal lo que quieres hacer, pero creo que podrías simplificarlo así: If (DriveType = DriveType. ALL Or Drive. DriveType = DriveType ) And (Drive. IsReady) Then If Name Then Drive_Info += Drive. Name & ";" If Label Then Drive_Info += Drive. VolumeLabel & ";" If Type Then Drive_Info += Drive. DriveType. ToString & ";" If Format Then Drive_Info += Drive. DriveFormat & ";" If Size Then Drive_Info += Drive. TotalSize. ToString & ";" If FreeSpace Then Drive_Info += Drive. TotalFreeSpace & ";" End If
Saludos.
|
|
|
En línea
|
- Nice to see you again -
|
|
|
Eleкtro
Ex-Staff
Desconectado
Mensajes: 9.878
|
@hdm
Muchas gracias, ese IF era lo que necesitaba!
|
|
|
En línea
|
|
|
|
HdM
Desconectado
Mensajes: 1.674
|
Ferpecto Elektro También podrías sustituir: If Name Then Drive_Info += Drive. Name & ";" If Label Then Drive_Info += Drive. VolumeLabel & ";" If Type Then Drive_Info += Drive. DriveType. ToString & ";" If Format Then Drive_Info += Drive. DriveFormat & ";" If Size Then Drive_Info += Drive. TotalSize. ToString & ";" If FreeSpace Then Drive_Info += Drive. TotalFreeSpace & ";"
Por una única línea: Drive_Info = IIf(Name, Drive. Name & ";", "") + IIf(Label, Drive. VolumeLabel & ";", "") + IIf(Type, Drive. DriveType. ToString & ";", "") + IIf(Format, Drive. DriveFormat & ";", "") + IIf(Size, Drive. TotalSize. ToString & ";", "") + IIf(FreeSpace, Drive. TotalFreeSpace & ";", "")
Teniendo en cuenta que: Si Option Strict tiene el valor On, debe utilizar la palabra clave CStr para convertir explícitamente el resultado de Object en String.
Saludos.
|
|
|
En línea
|
- Nice to see you again -
|
|
|
|
Mensajes similares |
|
Asunto |
Iniciado por |
Respuestas |
Vistas |
Último mensaje |
|
|
[Source] Infectar unidades extraibles (pendrive), unidades de red, etc...
« 1 2 »
Programación Visual Basic
|
Mad Antrax
|
11
|
9,382
|
7 Mayo 2007, 04:04 am
por jackl007
|
|
|
Detector unidades Pendrive 5.0c
« 1 2 ... 5 6 »
Scripting
|
carlitos.dll
|
50
|
29,922
|
3 Diciembre 2009, 04:36 am
por leogtz
|
|
|
Detectar Unidades USB (Pendrive) (SRC)
Programación Visual Basic
|
Hasseds
|
4
|
4,538
|
21 Abril 2009, 20:40 pm
por Hasseds
|
|
|
¿Como consigo la ip publica de dispositivos?
Dudas Generales
|
Crixus
|
6
|
2,926
|
27 Abril 2015, 00:17 am
por Crixus
|
|
|
Registrar / Monitorizar webs de dispositivos conectador por wifi
Redes
|
A.C.E.
|
5
|
3,229
|
9 Febrero 2017, 21:31 pm
por dato000
|
|