Solved

Code to validate an e-mail address in vb6

Posted on 2001-06-25
7
223 Views
Last Modified: 2010-05-02
Code to validate an e-mail address in vb6
0
Comment
Question by:global819
7 Comments
 
LVL 5

Expert Comment

by:rkot2000
ID: 6225174
you can use instr to search for @, . , com or net
0
 
LVL 20

Expert Comment

by:hes
ID: 6225318
have a look at this example

http://cuinl.tripod.com/Tips/string1.htm
0
 
LVL 49

Accepted Solution

by:
Ryan Chong earned 50 total points
ID: 6225916
Hi, here is a sample:

Dim IsValid As Boolean
Dim InvalidReason As String
   
IsValid = IsEMailAddress("karl@karlmoore.com", InvalidReason)

MsgBox "Is the e-mail address valid? - " & IsValid

MsgBox "If invalid, the reason given is: " & InvalidReason

_______________________________________________________

Public Function IsEMailAddress(ByVal sEmail As String, _
    Optional ByRef sReason As String) As Boolean
       
     Dim sPreffix As String
     Dim sSuffix As String
     Dim sMiddle As String
     Dim nCharacter As Integer
     Dim sBuffer As String

     sEmail = Trim(sEmail)

     If Len(sEmail) < 8 Then
          IsEMailAddress = False
          sReason = "Too short"
          Exit Function
     End If


     If InStr(sEmail, "@") = 0 Then
          IsEMailAddress = False
          sReason = "Missing the @"
          Exit Function
     End If


     If InStr(InStr(sEmail, "@") + 1, sEmail, "@") <> 0 Then
          IsEMailAddress = False
          sReason = "Too many @"
          Exit Function
     End If


     If InStr(sEmail, ".") = 0 Then
          IsEMailAddress = False
          sReason = "Missing the period"
          Exit Function
     End If

     If InStr(sEmail, "@") = 1 Or InStr(sEmail, "@") = Len(sEmail) Or _
          InStr(sEmail, ".") = 1 Or InStr(sEmail, ".") = Len(sEmail) Then
          IsEMailAddress = False
          sReason = "Invalid format"
     Exit Function

End If


For nCharacter = 1 To Len(sEmail)
     sBuffer = Mid$(sEmail, nCharacter, 1)
     If Not (LCase(sBuffer) Like "[a-z]" Or sBuffer = "@" Or _
     sBuffer = "." Or sBuffer = "-" Or sBuffer = "_" Or _
     IsNumeric(sBuffer)) Then: IsEMailAddress = _
     False: sReason = "Invalid character": Exit Function
Next nCharacter

nCharacter = 0

On Error Resume Next

sBuffer = Right(sEmail, 4)
If InStr(sBuffer, ".") = 0 Then GoTo TooLong:
If Left(sBuffer, 1) = "." Then sBuffer = Right(sBuffer, 3)
If Left(Right(sBuffer, 3), 1) = "." Then sBuffer = Right(sBuffer, 2)
If Left(Right(sBuffer, 2), 1) = "." Then sBuffer = Right(sBuffer, 1)


If Len(sBuffer) < 2 Then
     IsEMailAddress = False
     sReason = "Suffix too short"
     Exit Function
End If

TooLong:

If Len(sBuffer) > 3 Then
     IsEMailAddress = False
     sReason = "Suffix too long"
     Exit Function
End If

sReason = Empty
IsEMailAddress = True

End Function
0
How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

 
LVL 1

Expert Comment

by:vim_asteya
ID: 6226455
u can try this too


Dim v1, v2
If Len(email.Text) = 0 Then
    DoEvents
ElseIf Len(email.Text) > 0 Then
    v2 = (InStr(1, email.Text, "@", vbTextCompare))
    v1 = (InStr(1, email.Text, ".", vbTextCompare))

        If ((v2 > 0) And (v1 > 0)) Then
            DoEvents
        Else
            MsgBox "Invalid ID", , "Email"
            email.SetFocus
            email.Text = ""
        End If
End If

I use this code in my projects
0
 
LVL 49

Expert Comment

by:DanRollins
ID: 7139799
Hi global819,
It appears that you have forgotten this question. I will ask Community Support to close it unless you finalize it within 7 days. I will suggest to:

    Accept ryancys's comment(s) as an answer.

global819, if you think your question was not answered at all or if you need help, you can simply post a new comment here.  Community Support moderators will follow up.

EXPERTS: If you disagree with that recommendation, please post an explanatory comment.
==========
DanRollins -- EE database cleanup volunteer
0
 

Author Comment

by:global819
ID: 7140561
Thank you Randys
0
 
LVL 6

Expert Comment

by:Mindphaser
ID: 7144523
The answer is complete. I think that was a 'default' B, so I will change the grade to 'A'.

** Mindphaser - Community Support Moderator **
0

Featured Post

IT, Stop Being Called Into Every Meeting

Highfive is so simple that setting up every meeting room takes just minutes and every employee will be able to start or join a call from any room with ease. Never be called into a meeting just to get it started again. This is how video conferencing should work!

Join & Write a Comment

There are many ways to remove duplicate entries in an SQL or Access database. Most make you temporarily insert an ID field, make a temp table and copy data back and forth, and/or are slow. Here is an easy way in VB6 using ADO to remove duplicate row…
You can of course define an array to hold data that is of a particular type like an array of Strings to hold customer names or an array of Doubles to hold customer sales, but what do you do if you want to coordinate that data? This article describes…
Get people started with the process of using Access VBA to control Outlook using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Microsoft Outlook. Using automation, an Access applic…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…

743 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

Need Help in Real-Time?

Connect with top rated Experts

15 Experts available now in Live!

Get 1:1 Help Now