lunes, 22 de febrero de 2010

Formulario de Login en VS 2005

Introducción:

Esto es algo que mucha gente pregunta, pero que no tenía por aquí publicado, así que ya era hora.
El tema es que tenemos una aplicación de tipo "desktop" (Windows.Forms) en la que necesitamos que el usuario introduzca una clave para poder usarla. El problema con el que se encuentran algunos de los que intentan hacer esto es que escriben el código en el formulario principal y si la clave no es correcta, lo cierran, pero debido a como maneja Visual Studio .NET el tema de los formularios, al cerrar ese formulario principal, se cierra toda la aplicación... ¡incluso si la clave es correcta!
La solución es crear un formulario para comprobar esa clave, a ese formulario lo llamamos justo al iniciarse la aplicación, de forma que si la clave introducida es correcta, se muestre el formulario principal, y si no es correcta, cerramos la aplicación.

Crear el proyecto de ejemplo:

Los pasos que tenemos que dar para crear la aplicación de ejemplo son los siguientes:
  1. Crea un nuevo proyecto del tipo Windows.Forms (Aplicación para Windows).
  2. Tendremos un formulario llamado Form1, por simplicidad vamos a dejarle ese mismo nombre (Form1).
  3. Añade a ese formulario una etiqueta en la debes escribir lo que quieras, simplemente es para que sepas que es el formulario principal de tu aplicación. Por supuesto en este formulario es donde tendrás que hacer todo lo que tu aplicación deba hacer.
  4. Añade un segundo formulario al que le darás el nombre FormAcceso, inicialmente se llamará Form2, pero si le cambias el nombre justo al añadirlo, será más cómodo.
  5. En ese formulario de acceso, que será el que usemos para pedir la clave, añade una etiqueta, una caja de textos y dos botones.
  6. Modifica la propiedad FormBorderStyle para que tenga el valor FixedDialog.
  7. Asigna un valor False a las propiedades ControlBox, MaximizeBox y MInimizeBox.
  8. A la caja de textos dale el nombre txtClave y si no quieres que se vea la clave mientras se escribe, asigna un * a la propiedad PasswordChar.
  9. A los botones, le asignas los nombres btnAceptar y btnCancelar, y los textos Aceptar y Cancelar
    respectivamente.
  10. Sitúa esos controles donde más te guste, por ejemplo, puede tener un aspecto como el mostrado en la figura 1:
Figura 1. El formulario para la clave de acceso
Figura 1. El formulario para la clave de acceso
  1. Haz dobleclick en el botón de Cancelar y sustitúyelo por el siguiente código, en el que asignamos el valor Cancel al valor devuelto por la propiedad DialogResult que es el valor que devuelve el método
    ShowDialog de ese formulario (más abajo verás cómo se usa), en lugar de cerrar el formulario, lo ocultamos para que todo funcione mejor.
Private Sub btnCancelar_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) _
                Handles btnCancelar.Click
    Me.DialogResult = DialogResult.Cancel
    Hide()
End Sub
  1. Haz dobleclick en el botón Aceptar y escribe el código de más abajo, en el que hacemos la comprobación de si la clave escrita es la correcta, en este caso 123456, si es así, asignamos un valor OK y si no lo es, asignamos cualquier otro valor, ya que en nuestro código de validación, daremos como que la clave es correcta si tiene el valor OK. Aquí también ocultamos el formulario de las claves con Hide para que continúe la ejecución del programa y vuelva al código desde el que se ha mostrado este formulario.
Private Sub btnAceptar_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) _
                Handles btnAceptar.Click
    If txtClave.Text = "123456" Then
        Me.DialogResult = DialogResult.OK
    Else
        Me.DialogResult = DialogResult.No
    End If
    Hide()
End Sub
  1. En ambos casos, se supone que los nombres de los controles son como te he comentado, si no es así, pues deberás cambiar los nombres de los controles, así que, te recomiendo que para este ejemplo uses los nombres que te indico.
  2. Una vez hecho esto, ya tenemos el código del formulario que pide la clave de acceso.
  3. Tal como está el código solo tendrás un intento para escribir correctamente la clave, después veremos cómo cambiar el código para que tengas el número de intentos que quieras.
  4. Ahora vamos a modificar el código del formulario principal, aunque lo que tienes que escribir puede estar en cualquier otro formulario, lo recomendable es que esté en el que haga de formulario principal.
  5. Añade este código al formulario principal (Form1):
Public Class Form1
    Public Shared Sub Main()
        Application.EnableVisualStyles()
 
        Dim fAcceso As New FormAcceso
        If fAcceso.ShowDialog() = System.Windows.Forms.DialogResult.OK Then
            fAcceso.Close()
            Application.Run(New Form1)
        End If
    End Sub
 
End Class
  1. Con esto lo que hacemos es cargar el formulario que pide la clave, y si escribes la clave correcta, se cargará el formulario principal (Form1), si no es correcta, el valor devuelto por ShowDialog será distinto de OK, por tanto no se carga en memoria el formulario principal y se acabará la aplicación.
    Para cargar el formulario principal usamos Application.Run al que le pasamos el formulario que queremos que se utilice como inicio, es decir, ese formulario será el que mantenga la aplicación abierta, en cuanto se cierre el formulario principal (Form1) la aplicación finalizará.
  2. Lo siguiente que debemos hacer es decirle al Visual Basic que queremos que nuestra aplicación empiece por el método este que acabamos de escribir.
  3. En el menú Proyecto, seleccionamos Propiedades... (en realidad te mostrará Propiedades de y el nombre que le has dado al proyecto), esa misma opción la puedes conseguir al pulsar con el botón derecho del ratón en el proyecto del Explorador de soluciones, además puedes pulsar en el icono My Project que está también en el Explorador de soluciones. Una vez seleccionadas las opciones, te mostrará una ficha como la de la figura 2. Y tendrás que desmarcar la opción Habilitar marco de trabajo de la aplicación, de esa forma, en la lista desplegable que hay debajo de Objeto inicial, podrás seleccionar Sub Main, tal como te muestro en la figura 2:
Figura 2. En las propiedades del proyecto le indicamos que empiece con el código de Sub Main
Figura 2. En las propiedades del proyecto le indicamos que empiece con el código de Sub Main
  1. El problema que tenemos ahora es que los estilos de Windows XP ya no estarán habilitados por defecto, por eso en el código del Sub Main que te mostré antes está lo de Application.EnableVisualStyles, para que se usen los estilos de XP con la aplicación.
  2. Y una vez que has pulsado en Aceptar, puede probar a ver si todo funciona bien, para ello, pulsa en F5 y te mostrará el formulario de acceso, escribe 123456 y pulsa en Aceptar, verás que te muestra el
    formulario principal (Form1).
  3. Si pulsas en Cancelar o escribes mal la clave, se cerrará el programa.

Mejoras al código

Ahora vamos a mejorar un poco el código.
Lo primero que vamos a hacer es asignar a los botones del formulario que pide la clave la funcionalidad que normalmente suelen tener, aunque esto lo dejo a tu gusto, esa funcionalidad es que al pulsar Intro sea como si pulsáramos en el botón Aceptar, de esta forma, el usuario escribe la clave y pulsa Intro en tener que buscar el botón y hacer click, aunque también puede hacerlo y todo funcionará igual. La otra característica es que el botón Cancelar se asocie con la tecla ESC, de forma que si el usuario pulsa esa tecla sea lo mismo que si hubiera pulsando en Cancelar.
Para conseguir esto, debes hacer lo siguiente:
  1. Muestra el formulario de la clave de acceso y pulsa una vez en cualquier parte del formulario, pero no en ninguno de los controles.
  2. Ahora en la ventana de propiedades (si no la ves, pulsa F4), selecciona la propiedad AccepButton y de la lista desplegable (ver la figura 3) selecciona btnAceptar.
Figura 3. Asignar el botón predeterminado
Figura 3. Asignar el botón predeterminado
  1. Una vez hecho eso, verás que el botón Aceptar tiene un borde más oscuro, eso indica que es el botón predeterminado, por tanto será el que reciba la pulsación de la tecla Intro.
  2. Ahora selecciona la propiedad CancelButton y de la lista selecciona btnCancelar.
  3. Ya tienes esa funcionalidad, que puedes probar si inicias la aplicación (F5) y después de escribir la clave pulsas INTRO, verás que no tienes que hacer click en el botón Aceptar.
  4. Lo mismo ocurre si pulsas la tecla ESC, verás que se cierra la aplicación aunque la clave sea correcta, ya que en realidad es como si hubieras pulsado en el botón Cancelar.
Sigamos con las mejoras:

Permitir varios intentos fallidos antes de cerrar la aplicación

Como es posible que el usuario se equivoque al escribir o se olvide de la clave, vamos a darle algunas oportunidades más, por ejemplo tres.
Para hacer esto, tenemos que modificar el código del formulario de acceso, por tanto muestra el panel del código de ese formulario (FormAcceso) y antes del código que añadimos al principio, escribe esto:
Private veces As Integer = 0
Private Const NumeroIntentos As Integer = 3
La constante NumeroIntentos tendrá el valor de las veces que vamos a permitir que escriba la clave antes de darlo como cosa perdida y cerrar la aplicación.
Ahora escribe esto en el método del botón Aceptar, de forma que esto sea el nuevo código:
Private Sub btnAceptar_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) _
                Handles btnAceptar.Click
    If txtClave.Text = "123456" Then
        Me.DialogResult = DialogResult.OK
    Else
        ' Permitir varios intentos
        veces = veces + 1
        If veces < NumeroIntentos Then
            Label1.Text = "Quedan " & (NumeroIntentos - veces) & " intentos"
            Exit Sub
        End If
        Me.DialogResult = DialogResult.No
    End If
    Hide()
End Sub
Lo que hacemos es incrementar el contenido de la variable veces cada vez que se pulse en Aceptar, pero cuando la clave que escribimos no es la correcta, ya que si es correcta no hay que dar más intentos, je, je. Si el valor de esa variable en menor que el número máximo de intentos, modificamos el contenido de la etiqueta que hay junto a la caja de textos (Label1) para que muestre los intentos que quedan. Si superamos ese número se volverá al otro código y se acabará la aplicación.

Y esto es todo, espero que te haya resultado sencillo de comprender, y si ya tenías más experiencia, espero que sepas perdonar que lo haya explicado tan "paso a paso".
¡Que lo disfrutes!

No hay comentarios:

Publicar un comentario