elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.

 

 


Tema destacado: Únete al Grupo Steam elhacker.NET


  Mostrar Mensajes
Páginas: 1 ... 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 [19] 20 21 22 23 24 25 26 27 28 29 30 31
181  Foros Generales / Noticias / Re: La SGAE pagaba prostitutas para cuidar a "grupos de interés" en: 24 Noviembre 2011, 23:11 pm
¿Y no será que le pasaban una pesión a sus madres? :silbar:
182  Foros Generales / Foro Libre / Re: Creen en los ovnis? en: 24 Noviembre 2011, 23:00 pm
Carl Sagan lo explica muy bien:

Citar
En mi garaje vive un dragón que escupe fuego por la boca.

Supongamos (sigo el método de terapia de grupo del psicólogo Richard Franklin) que yo le hago a usted una aseveración como ésa. A lo mejor le gustaría comprobarlo, verlo usted mismo. A lo largo de los siglos ha habido innumerables historias de dragones, pero ninguna prueba real. ¡Qué oportunidad!

- Enséñemelo – me dice usted.

Yo le llevo a mi garaje. Usted mira y ve una escalera, latas de pintura vacías y un triciclo viejo, pero el dragón no está.

- ¿Dónde está el dragón? – me pregunta.

- Oh, está aquí – contesto yo moviendo la mano vagamente -. Me olvidé decir que es un dragón invisible.

Me propone que cubra de harina el suelo del garaje para que queden marcadas las huellas del dragón.

- Buena idea – replico -, pero este dragón flota en el aire.

Entonces propone usar un sensor infrarrojo para detectar el fuego invisible.

- Buena idea, pero el fuego invisible tampoco da calor.

Se puede pintar con spray el dragón para hacerlo visible.

- Buena idea, sólo que es un dragón incorpóreo y la pintura no se le pegaría.

Y así sucesivamente. Yo contrarresto cualquier prueba física que usted me propone con una explicación especial de por qué no funcionará.

Ahora bien, ¿cuál es la diferencia entre un dragón invisible, incorpóreo y flotante que escupe un fuego que no quema y un dragón inexistente? Si no hay manera de refutar mi opinión, si no hay ningún experimento válido contra ella, ¿qué significa decir que mi dragón existe? Su incapacidad de invalidar mi hipótesis no equivale en absoluta a demostrar que es cierta. Las afirmaciones que no pueden probarse, las aseveraciones inmunes a la refutación son verdaderamente inútiles, por mucho valor que puedan tener para inspirarnos o excitar nuestro sentido de maravilla. Lo que yo he pedido que haga es acabar aceptando, en ausencia de pruebas, lo que yo digo.

Lo único que ha aprendido usted de mi insistencia en que hay un dragón en mi garaje es que estoy mal de la cabeza. Se preguntará, si no se puede aplicar ninguna prueba física, qué fue lo que me convenció. La posibilidad de que fuera un sueño o alucinación entraría ciertamente en su pensamiento. Pero entonces ¿por qué hablo tan en serio? A lo mejor necesito ayuda. Como mínimo, puede ser que haya infravalorado la falibilidad humana.

Imaginemos que, a pesar de que ninguna de las pruebas ha tenido éxito, usted desea mostrarse escrupulosamente abierto. En consecuencia, no rechaza de inmediato la idea de que haya un dragón que escupe fuego por la boca en mi garaje. Simplemente, la deja en suspenso. La prueba actual está francamente en contra pero, si surge algún nuevo dato, está dispuesto a examinarlo a ver si le convence. Seguramente es poco razonable por mi parte ofenderme porque no me cree; o criticarle por ser un pesado poco imaginativo… simplemente porque usted pronunció el veredicto escocés de “no demostrado”.

Imaginemos que las cosas hubiesen sido de otro modo. El dragón es invisible, de acuerdo, pero aparecen huellas en la harina cuando usted mira. Su detector de infrarrojos registra algo. La pintura de spray revela una cresta dentada en el aire delante de usted. Por muy escéptico que se pueda ser en cuanto a la existencia de dragones – por no hablar de seres invisibles – ahora debe reconocer que aquí hay algo y que, en principio, es coherente con la idea de un dragón invisible que escupe fuego por la boca.

Ahora otro guión: imaginemos que no se trata sólo de mí. Imaginemos que varias personas que usted conoce, incluyendo algunos que está seguro que no se conocen entre ellas, le dicen que tienen dragones en sus garajes… pero en todos los casos la prueba es enloquecedoramente elusiva. Todos admitimos que nos perturba ser presas de una convicción tan extraña y tan poco sustentada por una prueba física. Ninguno de nosotros es un lunático. Especulamos con lo que significaría que hubiera realmente dragones escondidos en los garajes de todo el mundo y que los humanos acabáramos de enterarnos. Yo preferiría que no fuera verdad, francamente. Pero quizás todos aquellos mitos europeos y chinos antiguos sobre dragones no eran solamente mitos…

Es gratificante que ahora se informe de algunas huellas de las medidas del dragón en la harina. Pero nunca aparecen cuando hay un escéptico presente. Se plantea una explicación alternativa: tras un examen atento, parece claro que las huellas podían ser falsificadas. Otro entusiasta del dragón presenta una quemadura en el dedo y la atribuye a una extraña manifestación física del aliento de fuego del dragón. Pero también aquí hay otras posibilidades. Es evidente que hay otras maneras de quemarse los dedos además de recibir el aliento de dragones invisibles. Estas “pruebas”, por muy importante que las consideren los defensores del dragón, son muy poco convincentes. Una vez más, el único enfoque sensato es rechazar provisionalmente la hipótesis del dragón y permanecer abierto a otros datos físicos futuros, y preguntarse cuál puede ser la causa de que tantas personas aparentemente sanas y sobrias compartan la misma extraña ilusión.


Fuente: El Mundo y sus demonios
Carl Sagan
183  Foros Generales / Dudas Generales / Re: Requisitos para volver a sacar el DNI español? en: 21 Noviembre 2011, 21:45 pm
Y si lo has perdido más te vale ir deprisa a la comisaría a denunciar la pérdida y pedir uno nuevo porque a estas alturas cualquiera puede estar haciendo barrabasadas con tu DNI perdido. No serías el primero que pierde o le roban el DNI y un buen día recibe en su casa una reclamación de un crédito que él no ha pedido.
184  Informática / Hardware / Re: Se me cuelga el PC en: 17 Noviembre 2011, 21:37 pm
Una posible causa es que tengas algún ventilador mal y el ordenador se apague cuando se calienta demasiado. Revísalos.
185  Foros Generales / Foro Libre / Re: ¿Linchamiento publicitario a "La Noria"? en: 9 Noviembre 2011, 19:35 pm
No os hagáis ilusiones. Campofrío se ha marcado una campaña de imagen gratuita aprovechando el marketing viral de las redes sociales. Los demás se han visto obligados por la popularidad que ha tenido en las redes sociales la iniciativa de Campofrío.

La cruda realidad es que este último sábado el programa de La Noria ha tenido dos millones y medio de espectadores, record de la temporada. Ningún anunciante despreciará llegar a dos millones y medio de personas (público objetivo) así que en cuanto se calmen las aguas y la gente deje de hablar de esto, todos los anunciantes volverán a los intermedios de La Noria para llegar a esos dos millones de público objetivo que habitualmente ven el programa todos los sábados.

No nos engañemos: Las televisiones nos dan lo que queremos ver. Si hay tanto programa basura es porque existe una mayoría de personas que los ven. Si la mayoría de la gente viera los documentales de la 2, todas las cadenas nos forrarían a documentales, pero la gente ve programas de cotilleos y carnaza morbosa.
186  Foros Generales / Dudas Generales / Re: Base de datos Access No coinciden los tipos de datos en: 27 Octubre 2011, 21:17 pm
Pues lo más probable es que en el campo tamaño tengas algún valor que no es convertible a número.
187  Programación / Programación Visual Basic / Re: Visual Basic For Application. Objeto "Application.FileSearch" en Office 2007/10 en: 26 Octubre 2011, 20:00 pm
;D esta bien pero porque se escribe "Option Compare Database"


"Option Compare" determina el modo en que se compararán las cadenas de texto. En VBA para Access tiene tres valores posibles:
  • Binary: Realiza la comparación utilizando el orde que establece el código ASCII del caracter. Esta opción haría que al ordenar, la 'ñ' y la 'Ñ' vayan después de la Z ya que su código ASCII es mayor.
  • Text: Realiza la comparación de forma alfabética atendiendo a la configuración regional del sistema y sin distinguir mayúsculas de minúsculas.
  • Database: Realiza la comparación siguiendo el criterio configurado en la base de datos.
188  Programación / Programación Visual Basic / Visual Basic For Application. Objeto "Application.FileSearch" en Office 2007/10 en: 25 Octubre 2011, 22:37 pm
Tengo unas bases de datos de Access con macros en Visual Basic for Application hechas en la versión 2003 de Access. Ahora me he puesto a migrarlas a Access 2010 y me he encontrado con una sorpresa: El objeto "Application.FileSearch" dejó de implementarse en VBA a partir de la versión 2007 de Office.

Para los que no sepáis que hace el objeto, a grandes trazos es un objeto que permite configurar una serie de filtros para buscar ficheros, ejecuta la búsqueda y devuelve la lista de ficheros que cumplen con los criterios elegidos. Puedes, por ejemplo, pedirle la lista de ficheros "*.zip" que están en el directorio "C:\Temp" y que lo haga de forma recursiva buscando por los subdirectorios.

Después de mucho mirar por la ayuda y consultar al gran oráculo Google, descubrí que no sólo ha dejado de implementarse "Application.FileSearch", además su funcionalidad no ha sido sustituida por ningún otro objeto. Si quieres hacerlo tienes que implementarte a mano tu búsqueda de ficheros.

Entre los resultados de Google estaba el código de varios procedimientos para hacer lo mismo, incluido el que Microsoft proporciona en su web de soporte. Después de revisarlos todos y probar alguno, decidí implementar mi propio objeto FileSearch basándome en el procedimiento FileSearch que había implementado un tal Havrda y que yo encontré en http://www.pcreview.co.uk/forums/application-filesearch-error-t3743946p2.html

A continuación os pongo el objeto que he implementado por si alguno os encontráis con este problema en el futuro. La ventaja que tiene este objeto es que tiene un funcionamiento parecido al que tenía "Application.FileSearch" por lo que los cambios en vuestras macros serán menores que si intentáis adaptar un procedimiento de los muchos que encontraréis por Internet.


classError.cls
Objeto que agrupa el código de error y los mensajes que se producen dentro del objeto classFileSearch.

Código
  1. Option Compare Database
  2. Option Explicit
  3.  
  4.  
  5. Public iNumError        As Integer
  6. Public sDonde           As String
  7. Public sMensaSist       As String
  8. Public sMensaApli       As String
  9.  
  10.  
  11. Private Sub class_initialize()
  12.    On Error Resume Next
  13.  
  14.    Limpiar
  15. End Sub
  16.  
  17.  
  18. Public Sub Limpiar()
  19.    On Error Resume Next
  20.  
  21.    iNumError = 0
  22.    sDonde = ""
  23.    sMensaSist = ""
  24.    sMensaApli = ""
  25. End Sub
  26.  
  27. Public Sub Copiar(ByRef oObjOrigen As classError)
  28.    On Error Resume Next
  29.  
  30.    iNumError = oObjOrigen.iNumError
  31.    sDonde = oObjOrigen.sDonde
  32.    sMensaSist = oObjOrigen.sMensaSist
  33.    sMensaApli = oObjOrigen.sMensaApli
  34. End Sub
  35.  
  36.  


classFileSearch.cls
Objeto que realiza la búsqueda de los ficheros. La lista de ficheros encontrados es una colección de objetos "FILE".

Código
  1. Option Compare Database
  2. Option Explicit
  3.  
  4.  
  5. Public oError               As classError       ' Control de errores
  6. Public sDirIniBusqueda      As String           ' Directorio desde el que iniciar la búsqueda de ficheros
  7. Public sPatronBusqueda      As String           ' Patrón de búsqueda de ficheros. Por ejemplo: "*.rar"
  8. Public bBusquedaRecursiva   As Boolean          ' True: Busca recursivamente por los subdirectorios
  9. Public lstListaFicheros     As Collection       ' Lista de ficheros encontrados que coinciden con el patrón
  10.  
  11. Private objFileSystem       As Object
  12.  
  13.  
  14. Private Sub class_initialize()
  15.    On Error GoTo ERROR_CLASSINITIALIZE
  16.  
  17.    Set oError = New classError
  18.  
  19.    sDirIniBusqueda = ""
  20.    sPatronBusqueda = ""
  21.    bBusquedaRecursiva = False
  22.  
  23.    Set objFileSystem = CreateObject("Scripting.FileSystemObject")
  24.  
  25.    Exit Sub
  26.  
  27. ERROR_CLASSINITIALIZE:
  28.    oError.iNumError = Err.Number
  29.    oError.sMensaSist = Err.Description
  30.    oError.sDonde = "classFileSearch.class_initialize()"
  31.    oError.sMensaApli = "Error inicializando una instancia de la clase"
  32.  
  33. End Sub
  34.  
  35. Private Sub class_terminate()
  36.    On Error Resume Next
  37.    Set oError = Nothing
  38.    Set lstListaFicheros = Nothing
  39.    Set objFileSystem = Nothing
  40. End Sub
  41.  
  42. Public Function Ejecutar() As Integer
  43.    On Error GoTo ERROR_EJECUTAR
  44.  
  45.    Dim iIndice     As Integer
  46.    Dim sDirectorio As String
  47.    Dim sFichero    As String
  48.  
  49.  
  50.    If (sDirIniBusqueda = "") Then
  51.        oError.iNumError = -9999
  52.        oError.sMensaSist = ""
  53.        oError.sDonde = "classFileSearch.Ejecutar()"
  54.        oError.sMensaApli = "No se ha indicado ninguna ruta de directorio desde la que iniciar la búsqueda"
  55.        Ejecutar = -9999
  56.  
  57.    ElseIf (sPatronBusqueda = "") Then
  58.        oError.iNumError = -9999
  59.        oError.sMensaSist = ""
  60.        oError.sDonde = "classFileSearch.Ejecutar()"
  61.        oError.sMensaApli = "No se ha indicado ningún patrón de archivo a buscar"
  62.        Ejecutar = -9999
  63.    Else
  64.        '___Comprobar si la colección de ficheros tiene información, y si la tiene borrarla___
  65.  
  66.        Set lstListaFicheros = Nothing
  67.        Set lstListaFicheros = New Collection
  68.  
  69.        sDirectorio = Trim(sDirIniBusqueda)
  70.        sFichero = sPatronBusqueda
  71.  
  72.        BuscarFicheros sDirectorio, sFichero
  73.  
  74.        If (oError.iNumError = 0) Then
  75.            Ejecutar = lstListaFicheros.Count
  76.        Else
  77.            Ejecutar = -1
  78.        End If
  79.    End If
  80.  
  81.    Exit Function
  82.  
  83. ERROR_EJECUTAR:
  84.    oError.iNumError = Err.Number
  85.    oError.sMensaSist = Err.Description
  86.    oError.sDonde = "classFileSearch.Ejecutar()"
  87.    oError.sMensaApli = "Error ejecutando la búsqueda de ficheros indicada"
  88.    Ejecutar = -1
  89.  
  90. End Function
  91.  
  92. Private Sub BuscarFicheros(sDirectorio As String, sFichero As String)
  93.    On Error GoTo ERROR_BUSCARFICHEROS
  94.  
  95.    Dim sDirectorioFichero As String
  96.    Dim vSubdirectorio As Variant
  97.    Dim lstSubdirectorios As New Collection
  98.  
  99.  
  100.    '___Añade la barra de directorio al final del nombre de directorio si no la tuviera___
  101.  
  102.    If (Right(sDirectorio, 1) <> "\") Then
  103.        sDirectorio = sDirectorio & "\"
  104.    End If
  105.  
  106.  
  107.    '___Realiza la búsqueda de ficheros en el directorio actual___
  108.  
  109.    sDirectorioFichero = Dir(sDirectorio & sFichero)
  110.  
  111.    While (sDirectorioFichero <> "")
  112.        lstListaFicheros.Add objFileSystem.GetFile(sDirectorio & sDirectorioFichero)   'Añade el fichero a la lista de ficheros encontrados
  113.        sDirectorioFichero = Dir
  114.    Wend
  115.  
  116.  
  117.    '___Buscar en los subdirectorios si se ha definido la búsqueda como recursiva___
  118.  
  119.    If (bBusquedaRecursiva) Then
  120.  
  121.        sDirectorioFichero = Dir(sDirectorio & "*", vbDirectory)
  122.  
  123.        While (sDirectorioFichero <> "")
  124.  
  125.            If (sDirectorioFichero <> "." And sDirectorioFichero <> "..") Then
  126.                If ((GetAttr(sDirectorio & sDirectorioFichero) And vbDirectory) = 16) Then
  127.                    lstSubdirectorios.Add sDirectorio & sDirectorioFichero
  128.                End If
  129.            End If
  130.  
  131.            sDirectorioFichero = Dir
  132.        Wend
  133.  
  134.  
  135.        '___Procesar la lista de subdirectorios___
  136.  
  137.        For Each vSubdirectorio In lstSubdirectorios
  138.            BuscarFicheros CStr(vSubdirectorio), sFichero   'Llamada recursiva
  139.  
  140.            If (oError.iNumError <> 0) Then
  141.                Exit For
  142.            End If
  143.        Next
  144.    End If
  145.  
  146.    Exit Sub
  147.  
  148. ERROR_BUSCARFICHEROS:
  149.    oError.iNumError = Err.Number
  150.    oError.sMensaSist = Err.Description
  151.    oError.sDonde = "classFileSearch.BuscarFicheros()"
  152.    oError.sMensaApli = "Error en el procedimiento de búsqueda de ficheros"
  153.  
  154. End Sub
  155.  
  156.  


Procedimiento de prueba (.bas)
Esta es una pequeña función que lo único que hace es instanciar un objeto de la clase classFileSearch, lanzar una búsqueda y mostrar el resultado por la ventana de inspección.

Código
  1. Public Function fnMain() As Boolean
  2.    Dim objFileSearch   As classFileSearch
  3.    Dim objFichero      As Object
  4.  
  5.  
  6.    fnMain = True
  7.    Set objFileSearch = New classFileSearch
  8.  
  9.    If (objFileSearch.oError.iNumError = 0) Then
  10.  
  11.        '___Configurar los parámetros de búsqueda de fichero___
  12.  
  13.        objFileSearch.sDirIniBusqueda = "E:\Mis documentos"
  14.        objFileSearch.sPatronBusqueda = "*.zip"
  15.        objFileSearch.bBusquedaRecursiva = True
  16.  
  17.        If (objFileSearch.Ejecutar() > 0) Then  '_Se han encontrado ficheros
  18.  
  19.            For Each objFichero In objFileSearch.lstListaFicheros
  20.                Debug.Print "Fichero........: " & objFichero.Name
  21.                Debug.Print "Directorio.....: " & objFichero.parentfolder
  22.                Debug.Print "Nombre completo: " & objFichero.Path
  23.                Debug.Print "--------------------------"
  24.            Next objFichero
  25.  
  26.        ElseIf (objFileSearch.oError.iNumError = 0) Then   '_No hay error => No se han encontrado ficheros
  27.  
  28.            Debug.Print "No hay ficheros que mostrar"
  29.  
  30.        Else    '_Error
  31.  
  32.            Debug.Print "<* ERROR *>"
  33.            Debug.Print "   Lugar del error.......: " & objFileSearch.oError.sDonde
  34.            Debug.Print "   Número de error.......: " & objFileSearch.oError.iNumError
  35.            Debug.Print "   Error devuelto por VBA: " & objFileSearch.oError.sMensaSist
  36.            Debug.Print "   Error de aplicación...: " & objFileSearch.oError.sMensaApli
  37.            Debug.Print "--------------------------"
  38.  
  39.            fnMain = False
  40.        End If
  41.    Else
  42.        Debug.Print "<* ERROR *>"
  43.        Debug.Print "   Lugar del error.......: " & objFileSearch.oError.sDonde
  44.        Debug.Print "   Número de error.......: " & objFileSearch.oError.iNumError
  45.        Debug.Print "   Error devuelto por VBA: " & objFileSearch.oError.sMensaSist
  46.        Debug.Print "   Error de aplicación...: " & objFileSearch.oError.sMensaApli
  47.        Debug.Print "--------------------------"
  48.  
  49.        fnMain = False
  50.    End If
  51.  
  52.    Set objFileSearch = Nothing
  53. End Function
  54.  
  55.  


El código está probado y funciona. No implementa la funcionalidad completa de "Application.FileSearch" pero cubre lo más básico.

Supongo que viendo el código ya os habréis dado cuenta que el Visual Basic no es mi especialidad así que comentarios, sugerencias, críticas constructivas y mejoras serán bienvenidas ;)
189  Foros Generales / Dudas Generales / Re: Megabits o Megabytes. en: 22 Octubre 2011, 23:46 pm
mbps no significa megabytes por segundo, sino megabaudios por segundo, es un enredo del cual las compañias isp (provedoras de servicios a internet) no han querido aclarar por motivos comerciales.
1 baudio es la capacidad del modem de transformar la información analoga en digital, cada baudio es igual a un bit y 8 bits son 1 byte.

Esto es un error muy habitual. El baudio mide la cantidad de veces que cambia el estado una señal en una unidad de tiempo. Citando a Wikipedia que lo tiene muy bien explicado (http://es.wikipedia.org/wiki/Baudio):

Citar
Es importante resaltar que no se debe confundir el baud rate o velocidad en baudios con el bit rate o velocidad en bits por segundo, ya que cada evento de señalización (símbolo) transmitido puede transportar uno o más bits. Sólo cuando cada evento de señalización (símbolo) transporta un solo bit coinciden la velocidad de transmisión de datos baudios y en bits por segundo. Las señales binarias tienen la tasa de bit igual a la tasa de símbolos (rb = rs), con lo cual la duración de símbolo y la duración de bit son también iguales (Ts = Tb).

n = rb/rs

Donde rb: régimen binario o tasa de bits (bit rate) rs: tasa de modulación o tasa de símbolos y n: número de bits por nivel para la codificación de línea

Ejemplos:
- En el caso de las máquinas teletipo, todavía en uso en algunos medios, se decía que la velocidad de transmisión era normalmente de 50 baudios. En este caso, como los eventos eran simples cambios de voltaje 1-->(+), 0-->(-), cada evento representaba un solo bit o impulso elemental, y su velocidad de transmisión en bits por segundo coincidía con la velocidad en baudios.
- Sin embargo, en los módems que utilizan diversos niveles de codificación, por ejemplo mediante modulación de fase, cada evento puede representar más de un bit, con lo cual ya no coinciden bits por segundo y baudios.


Las velocidad de las líneas de comunicación se miden en Megabits/segundo.
190  Foros Generales / Dudas Generales / Re: Serial y logaritmo en: 22 Octubre 2011, 15:25 pm
Tendrías que hacer reingeniería del juego para ver el algoritmo de validación de la PC ID que calcula y la clave que te da la web. Pero no es algo sencillo de hacer si no tienes conocimientos previos de reingeniería y programación.
Páginas: 1 ... 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 [19] 20 21 22 23 24 25 26 27 28 29 30 31
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines