FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
|||
|
|||
Usuario Y Password Para Acceder A Una Aplicacion
Buenos Noche,
estoy desarrollando una aplicando con ORACLE EXPRESS 11g, y DELPHI 7, y en la parte de acceso de usuario y contrasena, estoy utilizando la vista de oracle DBA_USERS, que es donde tengo creado los usuarios, puesto que lo quiero manejar por ahi, para aprovechar las funcionalidades de seguridad de oracle, asi como tener una ventana de mantenimiento de usuario desde la aplicacion y asi no tener que introduccir usuario y password en el codigo del programa. El tema, es que he realizado todo bien, pero cuando presiono o pincho el boton siempre me devuelve el mensaje del message, que es "Usuario o PassWord Invalido" El Codigo es el siguiente: Si alguien me puede ayudar utilizando esta forma para hacerlo lo mas sencillo posible, ya que quiero configurar la mayor parte del trabajo por la base de datos, por ejemplo cantidad de intentos fallidos, cambio de claves periódicas, etc, ya que ORACLE me provee todo eso, y con esto me facilito la codificación en delphi. Espero por su ayuda. Rolando. Última edición por ecfisa fecha: 21-06-2011 a las 04:18:13. Razón: Etiquetas [DELPHI] [/DELPHI] |
#2
|
||||
|
||||
Esta consulta implica que ya hay una conexión activa sobre la base de datos, por lo que problema de conexión no es.
¿Has probado a ejecutar la consulta directamente sobre la bd de oracle? ¿devuelve los registros que esperas? También puede ser debido a que usas RecordCount del DataSet. Por experiencia, si no "navegas" hasta el ultimo registro, la propiedad RecordCount puede devolver resultados erróneos.
__________________
Progress Openedge https://abevoelker.com/progress_open...dered_harmful/ Delphi forever... |
#3
|
||||
|
||||
Porque no les gusta usar parametros como debe ser, jejejejeje.
ahi te va: En tu ADOQUERY pon esta sentencia SQL: Me imagino que manejas un campo ID o identificador.
Otra forma:
Porque dependiendo tu propiedad cursortype es si devuelve todos los registros. Bueno no siempre, pero si tienes registros devuelve -1 o los registros. Si no tienes siempre devuelve 0 (CERO) Y te doy un par de consejitos 1. Cambia el nombre de tus componentes: adoquery1 a aqyExisteUsuario 2. NO uses el adoquery usa el adodataset o el adocommand es mejor 3. si vas a usar el adoquery1 para otra consulta, mejor pon otro componente o crealo en tiempo de ejecucion. 4. Usa Datamodules te va a hacer la vida mas facil. Saludos
__________________
OEsqueda |
#4
|
|||
|
|||
Continua mi error
Buenas Noche,
Lo hice como me dijiste y me da el mismo error. Aqui algunas sentencias con modificaciones: Espero tu ayuda nuevamente. Bye, Rolando. Última edición por ecfisa fecha: 21-06-2011 a las 04:18:31. Razón: Etiquetas [DELPHI] [/DELPHI] |
#5
|
|||
|
|||
Error Logico Control De Acceso
Olvide decirte que las sentencias que le envie es para que me ayude a analizarla, ya que el error continua
Gracias, Rolando. |
#6
|
||||
|
||||
No contestaste a mis 2 preguntas:
¿Has probado a ejecutar la consulta directamente sobre la bd de oracle, sin ADO de por medio? ¿devuelve los registros que esperas? Supongo que esto será un error tuyo de transcripción: debe ser asi:
__________________
Progress Openedge https://abevoelker.com/progress_open...dered_harmful/ Delphi forever... |
#7
|
|||
|
|||
Acceso a una aplicacion introduciendo usuario y clave
Hola que tal todos mis amigos.
Hace varios dias estoy tratando de crear una aplicacion que acceda a una base de datos ORACLE EXPRESS 11G, y al crear el codigo y las configuraciones de propiedades el programa me corre bien, pero cuando introduzco el usuario y clave siempre me da que es incorrecto aunque lo introduzca bien. para validar el usuario, fue creado un registro en una tabla de la base de datos, y haciendo la consulta fuera de delphi me devuelve el valor correctamente. Anexo el codigo para ver si alguien me puede ayudar:
Este codigo lo tome del foro, y lo adapte a mi aplicacion. Un Saludo, Rolando. Última edición por Neftali [Germán.Estévez] fecha: 21-06-2011 a las 10:06:21. |
#8
|
||||
|
||||
Hola.
Por favor, utiliza TAG's cuando escribas código. En cuanto al código. ¿Lo has ejecutado paso a paso? Sería lo más sencillo para saber qué está fallando
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
#9
|
||||
|
||||
Cita:
Y recuerda leer nuestras normas, gracias. |
#10
|
|||
|
|||
Hola
Disculpa es que no tengo experiencia en el foro.
Ejecute el codigo linea por linea, y cuando llega al if, salta al showmessage, por lo que cambie el codigo y puse que si adoquery1.recordcount=0 que cargue el form2. Aparentemente, no esta guardando en memoria la consulta. o algo esta pasando que lo esta limpiando. que sera? |
#11
|
||||
|
||||
Hola
Es una simple validacion, el problema es que el parametro que coincide. Saludos
__________________
Siempre Novato |
#12
|
|||
|
|||
Hola
No entendi el comentario "Es una simple validacion, el problema es que el parametro que coincide"
Bye, Rolando. |
#13
|
|||
|
|||
Pon el codigo que tienes ahorita y donde te da el error..
|
#14
|
||||
|
||||
No trates de abarcar muchas cosas hasta no entender una plenamente. Me refiero a que antes de ponerte a manejar número de intentos inválidos y demás yerbas, primero te asegures que la consulta que quieres está funcionando.
Fíjate que en tu menaje original tienes esta consulta:
De entrada, esto es incorrecto, pues en lugar de or debería ser and, aunque en realidad, lo más adecuado sería simplemente:
es decir, sin la condición del password. Si encuentras una coincidencia, entonces sí, compara el password de la base con el que te dan. Otra cosa: realmente no es lo más adecuado usar RecordCount para determinar si se encontraron registros coincidentes. Lo más recomendable es usar el método IsEmpty. // Saludos |
#15
|
||||
|
||||
Totalmente de acuerdo.
Otra cosa que no entiendo rrosariom, es que has que cambiado por completo el código inicial (sobre el que respondí en el mensaje #18) . En ese mismo post, coincidiendo con los acertados consejos de roman, se usa and e IsEmpty en las comparaciónes. ¿ Probaste ese código ? Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#16
|
||||
|
||||
No me había fijado que ya defcon1_es había, desde un principio, hecho notar lo de RecordCount. Aunque no estoy de acuerdo con la solución propuesta de utilizar Last puesto que ello implica traerse todos los registros al cliente.
Pero otra cosa que recién noto, y que me parece que ahí puede estar el porque no encuentra coincidencias, es que la consulta (al menos la original) compara directamente la contraseña almacenada en la tabla con la que escribe el usuario. Pero eso no puede ser, porque la contraseña en la base está encriptada, tal como se lee aquí: Código:
PASSWORD VARCHAR2(30) Encrypted password Por otra parte, no se entiende en realidad cómo se están capturando los datos de usuario y contraseña; pues es bastante extraño usar DBEdits para ello. // Saludos |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
cambiar password del usuario sysdba | walace_soy | Firebird e Interbase | 27 | 23-06-2015 09:39:18 |
acceder a carpeta remota con password | chinchan | C++ Builder | 2 | 12-04-2011 13:33:59 |
validar dos campos (password y usuario) | Yessy | OOP | 18 | 28-07-2006 21:59:15 |
Usuario y Password con TQuery en MyODBC | mutant09 | Conexión con bases de datos | 9 | 23-04-2004 19:19:04 |
Dar Master Password a Paradox para que no lo haga el usuario | nefy | Conexión con bases de datos | 3 | 03-01-2004 19:01:30 |
|