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

ASP.NET Discussion :

Récupération de l'id utilisateur


Sujet :

ASP.NET

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Développeur Java
    Inscrit en
    Août 2008
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Août 2008
    Messages : 17
    Par défaut Récupération de l'id utilisateur
    Bonjour,

    J'ai un "petit" soucis :

    Je souhaite réaliser une page qui affiche une liste qui dépends de l'utilisateur courant.
    Pour ce faire, je fais un GridView et je lui associe un SqlDataSource.
    Cependant, je ne vois pas comment récupérer l'id de l'utilisateur car j'en ai besoin dans ma requête SQL.

    Voici ce que j'ai pour mon SqlDataSource :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
        <asp:SqlDataSource ID="RecupPrestataires" runat="server" 
            ConnectionString="<%$ ConnectionStrings:UsersInformations %>" 
            SelectCommand="SELECT us.UserName, ui.Adresse, ui.CodePostal, ui.Ville, ui.Tel
                            FROM vw_aspnet_Users us, Fournisseur_Prestataire fp, Users_Info ui
                            WHERE us.UserId = fp.PrestataireId AND us.UserId = @UserId" >
            <SelectParameters>
            </SelectParameters>
        </asp:SqlDataSource>
    L'idée que j'avais eu consistais à récupérer l'id dans la méthode Page_Load via la méthode MemberShip.GetUser et de l'ajouter dans les paramètres de la requête Select. Cependant, j'ai une erreur me disant que la variable @UserId n'est pas déclarée...

    Quelqu'un aurait une idée de comment je pourrai procéder? Ou bien y a-t-il moyen de récupérer cet id directement dans la requête?

    Merci d'avance.

  2. #2
    Membre émérite Avatar de Ramajb
    Homme Profil pro
    ----------------------------
    Inscrit en
    Septembre 2007
    Messages
    476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : ----------------------------

    Informations forums :
    Inscription : Septembre 2007
    Messages : 476
    Par défaut
    Il ne faut pas oublier de déclarer ton paramètre @UserId
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <SelectParameters>
         <asp:Parameter Name="UserId" DefaultValue="" />
    </SelectParameters>

  3. #3
    Membre averti
    Homme Profil pro
    Développeur Java
    Inscrit en
    Août 2008
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Août 2008
    Messages : 17
    Par défaut
    Merci, je n'ai plus l'exception en effet.

    Bien que cela fonctionne j'aimerai comprendre pourquoi ici, je dois déclarer UserId, alors que je fais sensiblement la même chose ailleurs (donc sans déclarer UserId et ajouter via le code behind) sauf qu'il s'agit d'un INSERT.

    Voici le code de l'INSERT qui fonctionne bien sans déclaration du paramètre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    <asp:SqlDataSource ID="InsertExtraInfo" runat="server"
                            ConnectionString="<%$ ConnectionStrings:UsersInformations %>" 
                            InsertCommand="INSERT INTO [Users_Info]([UserId], [Adresse], [CodePostal]) 
                                           VALUES (@UserId, @Adresse, @CodePostal)"
                            ProviderName="<%$ ConnectionStrings:UsersInformations.ProviderName %>">
                            <InsertParameters>
                                <asp:ControlParameter Name="Adresse" Type="String" ControlID="Adress" PropertyName="Text" />
                                <asp:ControlParameter Name="CodePostal" Type="String" ControlID="PostCode" PropertyName="Text" />
                            </InsertParameters>
                         </asp:SqlDataSource>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
                SqlDataSource dataSources = (SqlDataSource)container.FindControl("InsertExtraInfo");
                TextBox UserNameTextBox = (TextBox)container.FindControl("UserName");
                MembershipUser User = Membership.GetUser(UserNameTextBox.Text);
                object UserGUID = User.ProviderUserKey;
                dataSources.InsertParameters.Add("UserId", UserGUID.ToString());
                dataSources.Insert();

  4. #4
    Membre émérite Avatar de Ramajb
    Homme Profil pro
    ----------------------------
    Inscrit en
    Septembre 2007
    Messages
    476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : ----------------------------

    Informations forums :
    Inscription : Septembre 2007
    Messages : 476
    Par défaut
    Citation Envoyé par Spray Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    dataSources.InsertParameters.Add("UserId", UserGUID.ToString());
    Tout ce que tu fais dans aspx, tu peux le reproduire en code behind.
    Ce bout de code est équivalent à ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <SelectParameters>
         <asp:Parameter Name="UserId" DefaultValue="xxxx" />
    </SelectParameters>
    i.e que derrière il y a une déclaration de variable et après une affectation de valeur.
    Par contre tu ne peux pas faire ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    dataSources.InsertParameters["UserId"].value=, UserGUID.ToString();
    car cela suppose que tu as déjà déclaré la variable @UserId alors que c'est pas le cas.

Discussions similaires

  1. Récupération de nom d'utilisateur
    Par Thurial dans le forum Windows Forms
    Réponses: 2
    Dernier message: 09/11/2010, 10h35
  2. Réponses: 18
    Dernier message: 05/12/2008, 10h45
  3. Réponses: 1
    Dernier message: 04/04/2008, 10h32
  4. Cherche script de récupération du nom d'utilisateur
    Par nasbe26 dans le forum Général Dotnet
    Réponses: 3
    Dernier message: 20/12/2007, 11h09
  5. [LDAP] récupération login de l'utilisateur via Active Directory
    Par kcizth dans le forum Bibliothèques et frameworks
    Réponses: 6
    Dernier message: 21/12/2005, 16h47

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