FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Consulta sobre contraseña
Hola a todos, Se muy bien que en este foro hay ejemplos de contraseñas o logins, pero son un poquito mas avanzadas, yo estoy realizando uno con mis conocimientos basicos y solucionarlo de manera simple.
Les paso mi codigo procedure TForm1.Button1Click(Sender: TObject); var a,b: string; c:integer; begin a:=edit1.text; b:=edit2.Text; table1.First; edit1.SetFocus; c:=1; while table1.Eof = false do begin while c < 4 do begin //va a comparar en una tabla el apellido y la clave edit1.Clear; edit2.Clear; edit1.SetFocus; table1.Next; if (table1.FieldByName('Apellido').AsString = a) and (table1.fieldbyname('Clave').Asstring = b) then begin //si la clave es correcta va al formulario 2 form1.Hide; form2.show; table1.Next; c:=4; end else begin //si es incorrecta muestra un mensaje de error showmessage('Clave incorrecta'); end; c:=c+1; //incrementa en 1 al contador end; end; showmessage('adios'); // a los tres intentos fallidos muestra un mensaje y sale end; Pero resulta que si pongo mal la clave, me muestra el cartel y le tengo que dar tres veces ok para que vuelva al menu y volver a intentar. si le agrego close despues del cartel de "adios" sale del programa al primer mal intento. Agradesco cualquier correccion, dentro de los comandos utilizados. |
#2
|
||||
|
||||
Hola
Veamos algunas cosas: Que BD usas ?. Saludos
__________________
Siempre Novato |
#3
|
|||
|
|||
Las tablas las creo con el database desktop que trae Delphi
Ahi ve que pusistes algunos para que, seguramente en un Delphi mas avanzado esto sea una tonteria, pero hasta ahora es lo que me enseñaron. Por ejemplo cuando pongo table1.First; (para que? / Para que se situe en la primera posicion de la tabla edit1.SetFocus; (para que ? /Para que se posisione en el primer Edit while table1.Eof = false do (para que ? / Creo que era para que recorra toda la tabla form1.Hide; // no lo creo ?/ Es lo que me enseñaron para cerrar el formulario, al menos se que funciona. Es lo que te se explicar con lo que me enseñaron hasta el momento, voy a probar realizandoles esas modificaciones. form2.show;// con esto voy al formulario 2 Gracias. |
#4
|
||||
|
||||
Hola
Empecemos desde el principio. 1-Usas un Componente Table, eso quiere decir que seguramente lo abres al inicial el form. Lo mejor, cuando se usa ese componente es hacer un filtro, no recorrer la tabla completa. 2-Haces que el form 1 se esconda y se muestre el form 2. Lo mejor es que el form 1 llame al dos que es que que deberia ser el login. Saludos
__________________
Siempre Novato |
#5
|
||||
|
||||
Hola
Pregunto: Tienes que trabajar obligatoriamente con Paradox? o lo puedes hacer con otra BD ?. Saludos
__________________
Siempre Novato |
#6
|
|||
|
|||
Gracias Caral
Si tengo que usar Paradox y es correcto lo que decis. Se que algo esta mal, pero supuestamente con esas herramientas basicas lo deberia poder hacer, tiene que ser algo muy simple; crear una tabla con nombre y usuario, en Paradox y en Delphi un formulario en el cual ingresamos los datos y comparamos, si es correcto vamos al formulario2 y cerramos el primero. Si esta mal, lo indicamos con un mensaje y a los 3 intentos erroneos, se cierra el programa. Pense que iba a ser mas facil, pero hace una semana que ando dando vueltas con lo mismo |
#7
|
||||
|
||||
Hola
Quieres que hagamos el procedimiento como creo que deberia de ser ?. Saludos
__________________
Siempre Novato |
#8
|
||||
|
||||
Hola Compañero DOS!
Lo primero que debes hacer es declarar una variable en tu formulario. En esta variables almacenaras el número de intentos que ha hecho el usuario para iniciar sesión. Cuando esta variable llegue a 4, procedes a cerrar la aplicación. Puedes declarar la variable así:
Luego, en el botón para iniciar sesión, utiliza un código similar a este: Notarás que el código se hace un poco largo, pero es porque lleva notas explicativas. Además no es un código optimizado. Está basado en lo que tú ya has escrito. Aún así, espero que el código te sirva. Saludos, Chris |
#9
|
||||
|
||||
Hola
Bien, para empezar: 1- recorrer la tabla no es correcto, imaginate que tengas muchos datos, esto hace que el programa sea lento. 2- hacer o crear variables donde no se necesitas es gastar recursos, el programa crece innecesariamente. 3- Leer tanto el nombre como la clave en un solo IF es un error, ya que no necesariamente el usuario estara mal o la clave. Bueno, para mi algo sencillo es esto: Como ves, se filtra solo el nombre, si es el correcto entonces se filtra la clave, no se pierde tiempo ni recursos. Se inicia la cuenta desde la búsqueda del nombre. Se crea el form 2, no se hace desde el principio, es una mala practica. Simplemente se esconde el form 1, no hace falta nada mas. Se elimina el form 2 cuando el programa termina. Saludos
__________________
Siempre Novato |
#10
|
|||
|
|||
Gracias Chris
hice un copy paste en el programa y no corria, le hice unos pequeños cambios, segun la version anterior y asi corria, si pongo la clave bien, va al sig. form pero si es incorrecta sigue constantemente dando la opcion de cargar el U y la C pero nunca muestra el cartel ni termina la aplicacion. Disculpen muchachos si soy molesto y les agradesco nuevamente por su prontas respuestas y ayuda. /aprendi a recuadrar la sintaxis
. |
#11
|
||||
|
||||
Hola
Haciendo algunos cambios. Copia y pega este codigo: Ya esta probado, si tienes alguna duda el codigo tiene cada una de las explicaciones, cambia lo que necesites, asi practicas. Saludos
__________________
Siempre Novato Última edición por Caral fecha: 30-07-2011 a las 22:28:12. |
#12
|
||||
|
||||
Utiliza este código. Inicializaré la variable ClaveCorrecta para ver si es eso lo que te está dando problemas
Saludos, Chris |
#13
|
|||
|
|||
Muchas gracias, ya lo voy a probar, si bien hay varios comandos que todavia no conosco, vamos a ver que pasa. Despues les cuento. ; )
|
#14
|
||||
|
||||
Hola
Bueno, no se si al amigo DOS le funciona, pero a mi definitivamente no me funciona el codigo del amigo Chris, evidentemente no lo reviso, eso pasa. Aqui te dejo el codigo que hice (presiona el boton Caral) y el codigo de Chris (presiona el boton Chris), asi entenderas mejor el concepto y la diferencia. Esto esta hecho con BD access, pero es lo mismo, para que funcione en tu programa simplemente cambia donde veas ADOTABLE1 por Table1 y listo, copia y pega. Saludos PD: pruebalo con estos: usuario ( caral ) clave ( car ) Puedes equivocarte tanto en la clave como en el usuario.
__________________
Siempre Novato Última edición por Caral fecha: 31-07-2011 a las 20:25:15. |
#15
|
|||
|
|||
Bueno, Caral, no quiero que se cree una polemica o una pelea entre ustedes muchachos, Le agradesco la ayuda a ambos. En cuanto al programa puedo decir que Chris esta dentro de lo que conosco del lenguaje para tratar de encontrar la solucion, pero, si es verdad que no corre bien, talvez sea la parte del contador.
En cuanto al de Caral, sin dudas funciona, pero hay parte del lenguaje que todavia no he visto y se muy bien que se puede hacer con lo poco que se, sin dudas no sera algo optimo, pero es lo que tengo que realizar. Nuevamente muchas gracias por sus molestias e interes, que no he visto en ningun otro foro. |
#16
|
||||
|
||||
Hola
No es pelea ni polémica amigo, para nada, si bien es cierto yo no soy programador y Chris lo sabe, solo trato de hacer los ejemplos y probarlos, con mi poco conocimiento. Con relacion a lo que sabes o lo que quieres usar es lo mismo. Si te fijas bien en los dos codigos veras las diferencias, por eso puse los dos. 1- Filtrar, eso no es un problema, si quieres recorrer la tabla hazlo, no hay problema. 2- varables por cada edit, si lo quieres poner no hay problema. 3- revisar tanto el usuario como la clave con un solo IF, esto si que no me parece correcto ya que deberias dar la oportunidad del error en cada uno. 4- crear o devolver el foco solo a edit1 aunque sea la clave la del error me parece una equivocación, pero de que se puede se puede. 5- Mostrar el form2 directamente no es conveniente, es mejor crearlo y luego destruirlo. Como dije, no es pelea o polemica ni tampoco ver cual es el mejor codigo, solo es mostrar las diferencias. No puedo y eso lo tengo claro, competir contra un programador como Chris, pero tampoco lo quiero, solo trato de ayudar. Saludos
__________________
Siempre Novato |
#17
|
|||
|
|||
Gracias Caral, mañana, un poco mas despierto y descansado reelere los codigos y vere que pasa, saludos.
|
#18
|
||||
|
||||
Hola
Ya que entiendes mejor el codigo del amigo Chris veamos en lo que falla. 1- la variable que va sumando los intentos hay que declararla global, osea en donde se declara el form, aqui: Por que?, por que si se declara en el mismo procedimiento no suma, aquí el valor se suma. 2- Cuando la clave y el usuario son correctos el form 2 se abre, PERO al cerrarse el programa se cuelga, no se cierra, queda el form 1 ahi, pero no se ve, hay que eliminar el form 2 y cerrar el programa. Aqui te dejo el codigo, copialo y pegalo, ya esta probado. Saludos
__________________
Siempre Novato |
#19
|
|||
|
|||
Hola Caral
Debo decir que el programa funciona de maravillas, si bien todavia no vi el TRY y Finally, debe ser un poco mas avanzado a lo que vimos hasta ahora, seguramente para ti debe ser como tratar de que con las herramientas de un cavernicola trates de programar, asi que muchisimas gracias. |
#20
|
||||
|
||||
Hola
El asunto con el try y finally es que tal como dice en español: Try = trata de. finally = finalmente haz. Osea, al llamar a lo que sea, un procedimiento un form etc. lo que se intenta es que TRATE de hacerlo y una vez que lo haga termina o FINALIZA el proceso anterior. Saludos
__________________
Siempre Novato |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Realizar una consulta sobre los registros que devuelve otra consulta | Borjaserrano | Firebird e Interbase | 12 | 01-10-2007 23:19:44 |
Consulta sobre App MDI | MaMu | OOP | 4 | 15-07-2007 21:30:15 |
Consejo sobre uso de contraseña. | alfredosg19 | Varios | 2 | 08-03-2005 14:22:43 |
consulta sobre .ini | bytecero | Varios | 2 | 02-02-2005 21:01:09 |
|