Solved

How do I Validate a password entered in an Access 2003 Form with AD

Posted on 2009-05-04
5
312 Views
Last Modified: 2013-11-28
I have an Access 2003 DB Front-end with MS SQL 2005 Back-end.  Some of our shop users login to their PCs using a common "Shop" account.  They also have a "Personal" account for accessing MS Exchange e-mail using OWA so do have a personal AD account.

When these users open Access I wish them to "Login" using their normal AD Username & Password.

Any hints/code how I can achieve this?
0
Comment
Question by:CABHugh
  • 3
  • 2
5 Comments
 
LVL 22

Expert Comment

by:Paka
ID: 24302401
Are you shop owners on a common domain or are they accessing the Access/SQL through web app?
0
 

Author Comment

by:CABHugh
ID: 24302611
They are connectiong to a RDP session on Terminal Servers in our Data Centre.  They then open the Access 2003 Front-end in the session.  Each Receptionist in the Shop, up to 4, uses a common login for access but I wish Access to record the actual individual using that session.  As I've said, they do all have personal accounts as well so it would be easier for me to make use to that username and password rather than creating new passwords just for the DB which would be hard to maintain going forward.
0
 
LVL 22

Expert Comment

by:Paka
ID: 24302758
What kind of PCs do they have?  Would you be able to copy the Access front end to them and have the users log in using their AD accounts?   In this way, you would be able to integrated SQL authentication to enforce the security and auditing...
0
 

Author Comment

by:CABHugh
ID: 24302782
Not possible.  They are using TS over a ADSL VPN (Slow).  Everything runs on servers in the same datacentre so we get good local speed there.  I would like to open a login screen when Access opens and ask them to enter their personal AD Username & Password.  Im sure ther must then be a way, in VBA, to authenticate the credentials with AD.  If the authentication failed then the form would Quit the Access DB.

I just need that bit of VBA!!!
0
 

Accepted Solution

by:
CABHugh earned 0 total points
ID: 24305236
OK - I've got it working.

I have used the code here to query the AD with the Username & Password enterd in my Login Form.
If AD returns an error then the Credentials supplied are incorrect.  I give them 3 chances at enetering the correct data then Quit the DB.
Private Sub cmdLogin_Click()
On Error GoTo Err_Login
Dim strAuthUser As String
Dim strAuthPassword As String
Dim strAuthOUPath As String
Dim intRemain As Integer
Dim txtRemain As String
 
strAuthUser = Me.txtUser
strAuthPassword = Me.txtPassword
strAuthOUPath = "OU=ZZZ, OU=XXX"
Set oRoot = GetObject("LDAP:")
Set oOU = oRoot.OpenDSObject("LDAP://dc=YYY, dc=COM", "cn=" & strAuthUser & ", " & strAuthOUPath, strAuthPassword, ADS_SECURE_AUTHENTICATION)
 
Exit_Login:
    MsgBox "Login successful - Welcome", vbInformation, "Success..."
    CredentialsOK = True
    DoCmd.Close
    Exit Sub
 
Err_Login:
    If LoginAttempts = 3 Then GoTo Err_Login_Quit
    intRemain = 3 - LoginAttempts
    If intRemain = 1 Then
        txtRemain = " attempt remaining."
    Else
        txtRemain = " attempts remaining."
    End If
    MsgBox "Login Failed." & vbCrLf & vbLf & intRemain & txtRemain, vbCritical, "Failed..."
    Me.txtUser = ""
    Me.txtPassword = ""
    Me.txtUser.SetFocus
    LoginAttempts = LoginAttempts + 1
    Exit Sub
 
Err_Login_Quit:
    MsgBox "Login Failed.  Access denied.  Please contact Helpdesk for assistance.", vbCritical, "Quit..."
    DoCmd.Quit acQuitSaveNone
    Exit Sub
    
End Sub

Open in new window

0

Featured Post

Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

This article describes two methods for creating a combo box that can be used to add new items to the row source -- one for simple lookup tables, and one for a more complex row source where the new item needs data for several fields.
Access custom database properties are useful for storing miscellaneous bits of information in a format that persists through database closing and reopening.  This article shows how to create and use them.
With Microsoft Access, learn how to specify relationships between tables and set various options on the relationship. Add the tables: Create the relationship: Decide if you’re going to set referential integrity: Decide if you want cascade upda…
With Secure Portal Encryption, the recipient is sent a link to their email address directing them to the email laundry delivery page. From there, the recipient will be required to enter a user name and password to enter the page. Once the recipient …

713 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question