Solved

Code to validate an e-mail address in vb6

Posted on 2001-06-25
7
225 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 50

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
Gigs: Get Your Project Delivered by an Expert

Select from freelancers specializing in everything from database administration to programming, who have proven themselves as experts in their field. Hire the best, collaborate easily, pay securely and get projects done right.

 
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

Courses: Start Training Online With Pros, Today

Brush up on the basics or master the advanced techniques required to earn essential industry certifications, with Courses. Enroll in a course and start learning today. Training topics range from Android App Dev to the Xen Virtualization Platform.

Question has a verified solution.

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

Suggested Solutions

Introduction In a recent article (http://www.experts-exchange.com/A_7811-A-Better-Concatenate-Function.html) for the Excel community, I showed an improved version of the Excel Concatenate() function.  While writing that article I realized that no o…
The debugging module of the VB 6 IDE can be accessed by way of the Debug menu item. That menu item can normally be found in the IDE's main menu line as shown in this picture.   There is also a companion Debug Toolbar that looks like the followin…
Get people started with the utilization of class modules. Class modules can be a powerful tool in Microsoft Access. They allow you to create self-contained objects that encapsulate functionality. They can easily hide the complexity of a process from…
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…

776 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