Accueil > > > PROTEGER SON APPLICATION, AUTHENTIFICATION PAR COMPTES SYSTÈME [GRACE A ACTIVE DIRECTORY]
PROTEGER SON APPLICATION, AUTHENTIFICATION PAR COMPTES SYSTÈME [GRACE A ACTIVE DIRECTORY]
Information sur la source
Description
Bonjour tout le monde voici une petite application qui effectue une recherche des objets (Comptes utilisateurs humains du système) par des requettes dans AD et permet de lister les noms des comptes ainsi de vérifier les informations de login (Mot de passe) Grace a ce code, on peut proteger nos application par l'authentification intégrée du système d'exploitation.
Source
- Imports System.Management
- Imports System.DirectoryServices
-
- Public Class frmMain
-
- Private Sub GetSystemUsers()
- Me.Cursor = Cursors.WaitCursor
- Try
- 'Lecture du nom de domaine
- Dim localdomain As String = GetDomain()
- 'Lecture du nom de la machine.
- Dim localpc As String = Environment.MachineName
- Me.lblDomainName.Text += localdomain
- Me.lblMachineName.Text += localpc
- Application.DoEvents()
- 'Si le nom de domaine est unconnu.
- If localdomain = String.Empty Then
- 'L'objet dirEntry est un composant ajouté depuis le toolBox (Juste pour une info de +).
- dirEntry.Path = "WinNT://" + localpc
- Else
- dirEntry.Path = "WinNT://" + localdomain + "/" + localpc
- End If
- For Each child As DirectoryEntry In dirEntry.Children
- 'Prendre les utilisateurs humains de la machine
- If child.SchemaClassName = "User" Then
- Me.cbxUsers.Items.Add(child.Name)
- End If
- Next
- Catch ex As Exception
- MessageBox.Show("Erreur:" + ex.Message, "Erreur", MessageBoxButtons.OK, MessageBoxIcon.Error)
- End Try
- Me.Cursor = Cursors.Default
- End Sub
-
- Private Function GetDomain() As String
- Try
- 'Requette de recheche sur les informations du système.
- Dim squery As String = "SELECT * FROM Win32_ComputerSystem"
- 'Création d'un objet Management Searcher.
- Dim mgmtsearch As New ManagementObjectSearcher(squery)
- 'Recherche l'entrée Domain dans la liste des infos système.
- For Each item As ManagementObject In mgmtsearch.Get()
- Return item("Domain").ToString()
- Next
- Return String.Empty
- Catch
- Return String.Empty
- End Try
- End Function
-
- Private Sub Connect(ByVal userName As String, ByVal password As String)
- Try
- Dim de As New DirectoryEntry("LDAP://localhost/CN=Users;DC=" + lblDomainName.Text, lblDomainName.Text + "/" + userName, password, AuthenticationTypes.Secure)
- Dim test As Object = de.NativeObject ' Si cette propriété peut etre lu, donc les informations de connexion sont correctes.
- MessageBox.Show("Salut " + userName, "Authentication réussite", MessageBoxButtons.OK, MessageBoxIcon.Information)
- Catch e As Exception
- MessageBox.Show(e.Message, "Erreur:", MessageBoxButtons.OK, MessageBoxIcon.Error)
- End Try
- End Sub
-
- Private Sub btnConnect_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnConnect.Click
- Connect(cbxUsers.Text, txtPassword.Text)
- End Sub
-
- Private Sub btnClose_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnClose.Click
- Me.Close()
- Application.Exit()
- End Sub
-
- Private Sub frmMain_Shown(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Shown
- GetSystemUsers()
- End Sub
- End Class
Imports System.Management
Imports System.DirectoryServices
Public Class frmMain
Private Sub GetSystemUsers()
Me.Cursor = Cursors.WaitCursor
Try
'Lecture du nom de domaine
Dim localdomain As String = GetDomain()
'Lecture du nom de la machine.
Dim localpc As String = Environment.MachineName
Me.lblDomainName.Text += localdomain
Me.lblMachineName.Text += localpc
Application.DoEvents()
'Si le nom de domaine est unconnu.
If localdomain = String.Empty Then
'L'objet dirEntry est un composant ajouté depuis le toolBox (Juste pour une info de +).
dirEntry.Path = "WinNT://" + localpc
Else
dirEntry.Path = "WinNT://" + localdomain + "/" + localpc
End If
For Each child As DirectoryEntry In dirEntry.Children
'Prendre les utilisateurs humains de la machine
If child.SchemaClassName = "User" Then
Me.cbxUsers.Items.Add(child.Name)
End If
Next
Catch ex As Exception
MessageBox.Show("Erreur:" + ex.Message, "Erreur", MessageBoxButtons.OK, MessageBoxIcon.Error)
End Try
Me.Cursor = Cursors.Default
End Sub
Private Function GetDomain() As String
Try
'Requette de recheche sur les informations du système.
Dim squery As String = "SELECT * FROM Win32_ComputerSystem"
'Création d'un objet Management Searcher.
Dim mgmtsearch As New ManagementObjectSearcher(squery)
'Recherche l'entrée Domain dans la liste des infos système.
For Each item As ManagementObject In mgmtsearch.Get()
Return item("Domain").ToString()
Next
Return String.Empty
Catch
Return String.Empty
End Try
End Function
Private Sub Connect(ByVal userName As String, ByVal password As String)
Try
Dim de As New DirectoryEntry("LDAP://localhost/CN=Users;DC=" + lblDomainName.Text, lblDomainName.Text + "/" + userName, password, AuthenticationTypes.Secure)
Dim test As Object = de.NativeObject ' Si cette propriété peut etre lu, donc les informations de connexion sont correctes.
MessageBox.Show("Salut " + userName, "Authentication réussite", MessageBoxButtons.OK, MessageBoxIcon.Information)
Catch e As Exception
MessageBox.Show(e.Message, "Erreur:", MessageBoxButtons.OK, MessageBoxIcon.Error)
End Try
End Sub
Private Sub btnConnect_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnConnect.Click
Connect(cbxUsers.Text, txtPassword.Text)
End Sub
Private Sub btnClose_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnClose.Click
Me.Close()
Application.Exit()
End Sub
Private Sub frmMain_Shown(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Shown
GetSystemUsers()
End Sub
End Class
Sources du même auteur
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
LDAP [ par nicolas ]
Comment faire pour recuperer les données d'un serveur LDAPgrace en VB ou avec ASP
LDAP [ par toon ]
Je souhaite interroger un annuaire LDAP en VBSavez-vous comment faire ?A L'AIDE !!!!!!!!!!!!!!!!
administration annuaire ldap en VB [ par filouc ]
je dois faire le lien entre une base de données access et un annuaire sous openLDAP. la meilleure solution me semble etre le VB. de plus je dois fair
OUTLOOK et LDAP [ par jmt ]
Comment partager un annuaire LDAP (Serveur OpenLdap) entre tous mes clients OutLook 2000 pour qu'il soit visible comme un carnet d'adresse ?
Exchange - Ldap - Adsi - assoc-nt-account [ par JoPopo ]
Boujours !!!En ce vendredi tout gris sur paris, je cherhce deseperement à importer les noms de compte Nt associé aux boites aux lettres exchange. Notr
Erreur de connexion LDAP [ par adams36 ]
Bonjour,J'essaye de me connecter à un annuaire LDAP en asp de la manière suivante :Set oLDAP = GetObject(strSourceLdapPath)If Err.number <> 0 Th
Accès à l'annuaire LDAP Lotus Domino [ par cervel ]
J'ai besoin de récupérer des infos d'un annuaire LDAP de Lotus Domino dans des programmes VBS et ASP.J'utilise l'option GetObject mais cela ne me renv
Récupération de données LDAP Lotus Domino [ par cervel ]
Bonjour,Je voudrais récupérer certains champs d'un annuaire LDAP sous Lotus Domino dans des programmes VB6, VBS et ASP.Si quelqun connait une solution
LDAP [ par toky ]
Coment exporter une base Access vers LDAP ?
ADSI accéder à des attributs créés sur le serveur d'annuaire LDAP [ par mdelepin ]
Salut à tous,J'ai créer un schéma d'annuaire LDAP sur Sun One Directory Server 5.2 avec des attributs propres et des classes d'objets propres.Lorsque
|
Derniers Blogs
UNE JOLIE-HORLOGE ET PAS QU'UN PEU !UNE JOLIE-HORLOGE ET PAS QU'UN PEU ! par neodante
Pour les possesseurs d'iPhone, ça y est Bijin Tokei - qui se traduit littéralement en Français par " Jolie Horloge " - est arrivé et GRATUITEMENT s'il vous plaît ! Après la version Tokyo, Hokkaido, night club, racing, Gal, "pour les mademoiselles'", . voi...
Cliquez pour lire la suite de l'article par neodante TECHDAYS PARIS 2010 : CONNECTEZ VOS DONNéES à SHAREPOINT 2010 AVEC LES BUSINESS CONNECTIVITY SERVICESTECHDAYS PARIS 2010 : CONNECTEZ VOS DONNéES à SHAREPOINT 2010 AVEC LES BUSINESS CONNECTIVITY SERVICES par ROMELARD Fabrice
Animé par: Gaetan Bouveret et Julien Chomarat Business Connectivity Services (BCS) est dans SharePoint 2010 la version 2 de Business Data Catalog (BDC dans SharePoint 2007). Il s'agit de la solution permettant de visualiser des données provenan...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice [DIVERS] SUIVRE VOS SéRIES PRéFéRéS SUR LA TOILE[DIVERS] SUIVRE VOS SéRIES PRéFéRéS SUR LA TOILE par orion
Comme de nombreux geek, je suis un grand amateur de série TV et je rate régulièrement des épisodes de mes séries préférés. Une solution s'offre à vous avec ce merveilleux site : Tv Gorge - www.tvgorge.com Moteur de recherche à l'appui, vous pouvez ...
Cliquez pour lire la suite de l'article par orion TECHDAYS PARIS 2010 : LA BI DANS SHAREPOINT 2010TECHDAYS PARIS 2010 : LA BI DANS SHAREPOINT 2010 par ROMELARD Fabrice
Animé par: Vincent Bellet et Baptiste Giraudier La BI dans SharePoint 2010, Les nouveaux services d'application dans SP2010 et SQL Server Reporting services 2008 R2. La BI dans SharePoint est généralisée pour tous afin de permettre à tous les coll...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice
Logiciels
DB-MAIN (9.1.0)DB-MAIN (9.1.0)DB-MAIN is a data-modeling and data-architecture tool. It is designed to help developers and anal... Cliquez pour télécharger DB-MAIN Xilisoft DPG Convertisseur (5.1.37.0120)XILISOFT DPG CONVERTISSEUR (5.1.37.0120)Xilisoft DPG Convertisseur offre aux fans de Nintendo DS une bonne solution leur permettant de dé... Cliquez pour télécharger Xilisoft DPG Convertisseur GraphicsGale (2.01.01)GRAPHICSGALE (2.01.01)GraphicsGale est un logiciel de PixelArt avec de nombreuse fonctionnalités permettant de réalisé ... Cliquez pour télécharger GraphicsGale Architecte 3D (Platinum 2010)ARCHITECTE 3D (PLATINUM 2010)Architecte 3D Platinium vous permet de concevoir facilement les plans votre future maison, de l'é... Cliquez pour télécharger Architecte 3D TeamViewer 5 (TeamViewer 5)TEAMVIEWER 5 (TEAMVIEWER 5)Dépanner un ami,expliquer une manipulation devient un jeu d'enfant.
Prise en main d'un autre ord... Cliquez pour télécharger TeamViewer 5
|