Saltar al contenido

Abrir Base Access cifrada con clave


Recommended Posts

publicado

Estimados recurro nuevamente con otra consulta,

Estoy trabajando con access y ahora quiero incorporar clave a la BD, no logro crear una cadena de conexión valida, copio código donde abro la base y carga un combobox,

Ingresa siempre a If cn.State <> 1 , no reconoce la clave prpporcionada 

Saludos.

 

Private Sub CargarComboFormRubrado()

    Dim cn As Object
    Dim datos As Object
    Dim consultaSQL As String
    Dim conexion As String
    Dim rutaBaseDatos As String
    Dim contraseña As String
    
    ' Obtengo la ruta donde se encuentra el archivo de Excel actual
    rutaBaseDatos = ThisWorkbook.Path & "\Rbo.accdb"
    
    ' Verificar si la base de datos existe en la ruta proporcionada
    If Not CheckDatabaseExistence(rutaBaseDatos) Then
        Exit Sub
    End If
    
    ' Establece la contraseña de base de datos cifrada
    contraseña = "1234"
    
    ' Crea la cadena de conexión con la contraseña
    conexion = "Provider=Microsoft.ACE.OLEDB.12.0;" & _
        "Data Source=" & rutaBaseDatos & ";Jet OLEDB:Database Password=" & contraseña
    
    Set cn = CreateObject("ADODB.Connection")
    
    ' Abrir la conexión a la base de datos con la contraseña
    On Error Resume Next
    cn.Open conexion
    On Error GoTo 0
    
    ' Verifica si se pudo abrir la base de datos con la contraseña
    If cn.State <> 1 Then
        MsgBox "Error al abrir la base de datos. Verifica la contraseña.", vbExclamation, "Error"
        Exit Sub
    End If
    
    consultaSQL = "SELECT * FROM TRUBRADO" ' Nombre tabla access
    
    ' Crear el objeto Recordset y abrir la consulta
    Set datos = CreateObject("ADODB.Recordset")
    datos.CursorLocation = 3 ' adUseServer
    datos.Open consultaSQL, cn
    
    ' Validar si la consulta devuelve resultados
    If datos.EOF And datos.BOF Then
        ' Cerrar la conexión y liberar recursos
        datos.Close
        cn.Close
        Set datos = Nothing
        Set cn = Nothing
        
        Application.EnableCancelKey = xlDisabled
        MsgBox "No hay resultados", vbInformation, "INFO"
        Exit Sub
    End If
    
    ' Limpiar ComboBox1
    Me.CbxRubrado.Clear
    
    ' Recorrer el Recordset y cargar datos en ComboBox1
    Do While Not datos.EOF
        Dim campoID As String
        Dim campoNombre As String
        
        campoID = ControloNull(datos.Fields(0))
        campoNombre = ControloNull(datos.Fields(1))
        
        ' Agregar el campoNombre al ComboBox
        Me.CbxRubrado.AddItem campoNombre
        
        ' Guardar el campoID en la propiedad List del ComboBox
        Me.CbxRubrado.List(Me.CbxRubrado.ListCount - 1, 1) = campoID
        datos.MoveNext
    Loop
    
    ' Cerrar la conexión y liberar recursos
    datos.Close
    cn.Close
    Set datos = Nothing
    Set cn = Nothing

End Sub

publicado

Para ampliar información proporciono el numero de error 

Error 3709 

"No se puede utilizar la conexión para realizar la operación. Está cerrada o no es válida en este contexto"

La clave es correcta porque desde access se ingresa

Si contraseña el código funciona correctamente

 

publicado
hace 40 minutos , Juan Suarez dijo:

Bueno, tengo problemas con la instalación entonces!

Podría se un tema de controladores ACE o alguna referencia ?

 

 

Lo siento, ahí no llego.

publicado

Hola Juan

Abre tu archivo Access y elimina la clave, luego en Archivo - Opciones - Configuración del cliente - Avanzadas - busca "Método de cifrado" y elige "Usar cifrado heredado" y dale clic al botón "Aceptar". Crea la clave otra vez y vuelve a intentar con tu macro. Saludos.

Archivado

Este tema está ahora archivado y está cerrado a más respuestas.

  • 109 ¿Te parecen útiles los tips de las funciones? (ver tema completo)

    1. 1. ¿Te parecen útiles los tips de las funciones?


      • No
      • Ni me he fijado en ellos

  • Ayúdanos a mejorar la comunidad

    • Donaciones recibidas este mes: 0.00 EUR
      Objetivo: 130.00 EUR
  • Archivos

  • Estadísticas de descargas

    • Archivos
      187
    • Comentarios
      97
    • Revisiones
      28

    Más información sobre "Un juego del Rabino en Excel"
    Última descarga
    Por pegones1

    1    1

  • Crear macros Excel

  • Mensajes

    • Hola La opción brindada por @torquemada es correcta, funciona, pero hay algunos inconvenientes que (desde mi punto de vista) no la convierten en mi primera elección. Los inconvenientes son: Tendrías que ir columna por columna haciendo los reemplazos, claro que no se harían a mano sino que utilizarías la opción reemplazar o la opción texto en columnas, aun asi demorará un poquito y será trabajoso. Cada vez que descargues otro listado, tendrás que volver a realizar los reemplazos. Me parece una mejor propuesta lo siguiente: Descarga los movimientos a un archivo de Excel Desde tu control de pagos (otro archivo) cargas los movimientos del archivo descargado mediante Power Query Power Query hará los reemplazos y reconocerá todo correctamente (sin que tengas que hacer nada especial) Cuando descargues los movimientos un día posterior, solamente tendrás que hacer clic en "Actualizar" y todo funcionará en automático
    • Hola a todos, Efectivamente, me temo que tal como trabajan las funciones =HOY() y/o =AHORA() (volátiles), sólo con macros puedes obtener soluciones. Un recurso pedestre podría ser, cada vez que quieras que se fije un dato, te sitúes en esa celda y pulses F2, F9 e INTRO.  Pero claro, puede ser un inconveniente si hay que hacerlo repetitivamente en muchas ocasiones,.............. en fin, lo comento sólo como posibilidad. Saludos,
    • Hola nuevamente, mi duda sigue siendo la ruta, o rutas, finales que quedan, esas que llamas "relativas"; igual por si acaso pon 3 o 4 de esas, tal cual son y/o se ven en el explorador de cada PC y, de ser posible, en cualquier otro "lado" en que las veas.
    • Hola, tal cual se plantea, solamente con macros (VBA); en todo caso, hacerlo a mano o con "CTRL + ;". Saludos.
    • Mil gracias, en verdad todo apoyo es super agradecido,   Su aporte y comentarios valen mucho para in servidor, y tiene razon esperare a conocer si alguien comparte alguna otra manera,   Gracias!!! (y)
  • Visualizado recientemente

    • No hay usuarios registrado para ver esta página.
×
×
  • Crear nuevo...

Información importante

Echa un vistazo a nuestra política de cookies para ayudarte a tener una mejor experiencia de navegación. Puedes ajustar aquí la configuración. Pulsa el botón Aceptar, si estás de acuerdo.