?
Solved

Code to validate an e-mail address in vb6

Posted on 2001-06-25
7
Medium Priority
?
232 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 54

Accepted Solution

by:
Ryan Chong earned 200 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
Industry Leaders: 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!

 
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

VIDEO: THE CONCERTO CLOUD FOR HEALTHCARE

Modern healthcare requires a modern cloud. View this brief video to understand how the Concerto Cloud for Healthcare can help your organization.

Question has a verified solution.

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

Most everyone who has done any programming in VB6 knows that you can do something in code like Debug.Print MyVar and that when the program runs from the IDE, the value of MyVar will be displayed in the Immediate Window. Less well known is Debug.Asse…
Background What I'm presenting in this article is the result of 2 conditions in my work area: We have a SQL Server production environment but no development or test environment; andWe have an MS Access front end using tables in SQL Server but we a…
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…
Get people started with the process of using Access VBA to control Excel using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Excel. Using automation, an Access application can laun…
Suggested Courses

850 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