IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Oracle Discussion :

Retour de fonction d'une JSP / Procedure


Sujet :

Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Étudiant
    Inscrit en
    Octobre 2005
    Messages
    29
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2005
    Messages : 29
    Par défaut Retour de fonction d'une JSP / Procedure
    Bonjour,

    on est entraint de créer une Java Stored Procedure pour l'identification dans une application java.

    On a également créé une procedure afin de pouvoir la lancer. Notre problème est qu'on voudrait récupérer ce que la JSP renvoi, mais on ne sait pas du tout comment !
    on a essayé avec des getInt(), etc... mais rien à faire....
    Voici les différentes sources:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    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
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
          CREATE OR REPLACE JAVA SOURCE NAMED "Login" AS
        public class Login {
            public static void autorise(String nom, String mdp, int b) 
            {
                java.lang.String requeteMdp = new String();
                java.lang.String url = "jdbc:default:connection";
                java.sql.Connection conn ;
                java.sql.Statement stmt ;
    
                try{
                conn = java.sql.DriverManager.getConnection(url);
                stmt = conn.createStatement();
                
    
                java.sql.ResultSet rs = stmt.executeQuery("SELECT mdp FROM personne WHERE nomPersonne='" + nom +"'");
    
                while(rs.next())
                 {
                    requeteMdp = rs.getString("mdp") ;
                 }
    
                stmt.close();
                conn.close();
    
                }
            
                catch(java.sql.SQLException e)
                {
                    System.out.println("Erreur SQL:");
                }
    
                if(mdp.compareTo(requeteMdp)!=0)
                {
                    b= 0;
                }
                else
                b= 1;
                
    
            }
    
    
        };
    
    /
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
          CREATE OR REPLACE PROCEDURE myLogin(name VARCHAR2, mot VARCHAR2, b NUMBER ) AS LANGUAGE JAVA
    NAME 'Login.autorise(java.lang.String, java.lang.String, int)';
    /
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    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
    32
          public void actionPerformed(ActionEvent event)
                {
                    int b = 0;
                    
                        nomUtilisateur  = JOptionPane.showInputDialog( "Veuillez rentrer votre nom d'utilisateur");
                        String requeteMdp = new String() ;
                        try {
                        ResultSet rs = stmt.executeQuery("select * from personne where nompersonne='" + nomUtilisateur + "'")  ;
                        
                        while (rs.next())
                        {
                            requeteMdp = rs.getString("mdp") ;
                        }
                        }
                        catch (SQLException e)
                        {
                            System.out.println("Erreur sql") ;
                        }
                    
                    String mdp  = new String() ;
                    if (nomUtilisateur!=null)
                    mdp = JOptionPane.showInputDialog( "Veuillez rentrer votre mot de passe");
                    
                                    try {
                    ResultSet rs = stmt.executeQuery("call myLogin('" + nomUtilisateur + "','" + mdp + "'," + b + ")")  ;
                    while (rs.next())
                    {
                        res = rs.getInt(3) ;
                    }
                    }                    
                        
                        ......

  2. #2
    Membre émérite Avatar de plabrevo
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    548
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 548
    Par défaut
    La procedure PL/SQL doit d'abord declarer le 3eme parametre en IN OUT afin qu'il puisse etre retourne a la fonction appellante.

    Ensuite, je m'etonne aucune erreur ne soit retournee, mais la fonction PL/SQL doit etre executee a l'aide d'un prepareCall(), suivi d'un execute(), tous les parametres out ayant ete prealablement declares a l'aide d'un registerOutParameter().

Discussions similaires

  1. Retour de fonction contenant une "liste" - Conventions ?
    Par Jimalexp dans le forum Langages de programmation
    Réponses: 2
    Dernier message: 26/01/2009, 14h08
  2. Réponses: 4
    Dernier message: 30/09/2008, 18h13
  3. Appel de fonction dans une page JSP
    Par Addouna dans le forum Servlets/JSP
    Réponses: 6
    Dernier message: 09/03/2006, 12h56
  4. Utilisation d'une fonction dans une procedure
    Par MaxiMax dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 09/08/2005, 15h51
  5. retour de variable d'une fonction
    Par thunderblade dans le forum ASP
    Réponses: 4
    Dernier message: 28/04/2005, 13h27

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo