Bienvenue à Blogs CodeS-SourceS Identification | Inscription | Aide

The Mit's Blog

En plus d'intégrer et skier, il sait même écrire !
(Blog de Renaud Comte)

Actualités

RunWithElevatedPrivileges : Attention au piége de l'impersonnation

Un petit piége qui n'as l'air de rien mais qui peut vous bloquer bien des heures.

Le principe de l'impersonnation est assez simple

>>> Vous exécutez une partie de votre processus sous une identité tierce, souvent un role à pouvoir genre owner/power users (ou pire ... admin)

Simple me dirait vous ? Et encore plus sous SharePoint grace à la méthode : SPSecurity.RunWithElevatedPrivileges.

Et la : ATTENTION AU PIEGE

En effet, la plupart des développeurs SharePoint affectionnent grandement l'objet SPWeb, et de toute maniére, il est difficilement contournable dans le contexte d'un site SP non ?

Le piége est la :

SPSecurity.RunWithElevatedPrivileges(delegate(){

                    SPWeb web = SPContext.Current.Web; 
...
...

});

Dans ce cas, l'impersonnation ne joue pas !!!
>>> Celui ci est créé directement selon le contexte de l'utilisateur en cours et non la zone impersonnée, soit l'identité du pool applicatif.

Pour être sur d'utiliser le bon contexte de sécurité avec le SPWeb, vous devez absolument le créer de toute piéce dans le dit contexte.

Et non devoir le référencer

Puis surtout ensuite, le supprimer bien sur.

Il y a plusieurs méthodes :

Mais j'ai une préférence pour celle ci :

Guid webGuid = SPContext.Current.Web.ID;
Guid siteGuid = SPContext.Current.Site.ID;

SPSecurity.RunWithElevatedPrivileges(delegate()
                {
                    // get the site in impersonated context
                    using (SPSite site = new SPSite(siteGuid))
                    {

                        // get the web in the impersonated context
                        SPWeb web = site.OpenWeb(webGuid);
                       // Do your work here   

                     web.Dispose(); 
                    }

               });

Tout est clair et explicite, pas de doute ni de gestion d'url.

Voila, maintenant, votre Code est désormais "application pool" powered !
>>> Faites bien attention quand même Wink

Renaud Comte aka TheMit (SPprison Break?)
Member of WygTeam
http://www.wygwam.com

Ce post vous a plu ? Ajoutez le dans vos favoris pour ne pas perdre de temps à le retrouver le jour où vous en aurez besoin :
Posted: vendredi 17 août 2007 15:48 par themit
Classé sous : , ,

Commentaires

Pas de commentaires

Les commentaires anonymes sont désactivés

Les 10 derniers blogs postés

- Kinect 1.5 is out ! par Cyril Sansus le 05-21-2012, 17:47

- Les actualités de la semaine sur c2i.fr (14 mai - 20 mai) par Richard Clark le 05-21-2012, 08:50

- Reactive Extensions : Consommer des services avec Rx Partie 3, les pièges à éviter par Léonard Labat le 05-20-2012, 23:45

- SharePoint Blog Site, problème d’archives par Le Blog (Vert) d'Arnaud JUND le 05-20-2012, 13:09

- Soirée ALT.NET Mai - 3 présentations par #Rui le 05-18-2012, 11:59

- [ #SharePoint 2010][ #SQLServer 2012] AlwaysOn pour SharePoint (2/4) : Configuration (2e partie)… par Le blog de Patrick [MVP SharePoint] le 05-18-2012, 11:31

- Team Foundation Server 11: tous les trésors cachés du site d’équipe par Philess le 05-16-2012, 19:01

- [PowerShell 3] Télécharger et installer la documentation en ligne par Blog de SPBrouillet (Pierrick BROUILLET) le 05-16-2012, 17:36

- [#SharePoint 2010][#SQLServer 2012] AlwaysOn pour SharePoint (1/4) : Configuration (1ère partie)… par Le blog de Patrick [MVP SharePoint] le 05-16-2012, 12:10

- Job Day @MIC Brussels - .Net Developers on Mobile applications par Le Blog (Vert) d'Arnaud JUND le 05-15-2012, 20:26