Trucsweb.com

Trucsweb.com

ASP

Validation de formulaire

RDFFav

Validation de courriel - Très poussée

Validates email addresses for valid characters. Also compares IP email addresses to make sure they are not any of the assigned private network ip addresses.email validationValidation de courriel - Très poussée
  • · Niveau : AVANCÉ
  • · Compatibilité : Windows NT/2000 IIS3

Validates email addresses for valid characters. Also compares IP email addresses to make sure they are not any of the assigned private network ip addresses.

<%
Function IsEmail(ByRef asString)
Dim lsDomain
Dim lsSubDomain
Dim lsSubDomainArray
Dim lbIsIPdomain
Dim lnStart
Dim lsUserName
Dim lnOctect
Dim lnOctect2
Dim lnIndex

Const lsDOMAIN_CHARACTERS = "".ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890-""

’ Must have at least 6 characters ""a@a.ru""
If Len(asString) < 6 Then
IsEmail = False
Exit Function
End If

’ Look for ""@"" delimiter
If Not InStr(asString, ""@"") > 1 Then
IsEmail = False
Exit Function
End If

’ Make sure characters exist after the ""@""
If Len(asString) = InStr(asString, ""@"") Then
IsEmail = False
Exit Function
End If

’ Grab domain information ""a.ru""
lsDomain = UCase(Mid(asString, InStr(asString, ""@"") + 1))

’ Grab username information
lsUserName = UCase(Left(asString, InStr(asString, ""@"") - 1))

’ Make sure at least 1 ""."" exists
If InStr(lsDomain, ""."") = 0 Then
IsEmail = False
Exit Function
End If

’ Check for valid domain characters
lnStart = 1
Do While lnStart <= Len(lsDomain)
If InStr(lsDOMAIN_CHARACTERS, Mid(lsDomain, lnStart, 1)) Then
lnStart = lnStart + 1
Else
IsEmail = False
Exit Function
End If
Loop

’ Split domains
lsSubDomainArray = Split(lsDomain, ""."")
lbIsIPdomain = False

’ Loop through each domain
For lnIndex = 0 To UBound(lsSubDomainArray, 1)
lsSubDomain = lsSubDomainArray(lnIndex)
If Len(lsSubDomain) = 0 Then
IsEmail = False
Exit Function
End If

’ Check to see if the domain is an IP Address
If lnIndex = 0 Then
If IsNumeric(lsSubDomain) Then

’ Only IP Addresses can have only numbers in subdomain area
lbIsIPDomain = True

’ Make sure 4 subdomains are present
If Not UBound(lsSubDomainArray, 1) = 3 Then
IsEmail = False
Exit Function
End If

End If
End If

If lbIsIPDomain Then
If Len(lsSubDomain) > 3 Then
IsEmail = False
Exit Function
ElseIf Not InStr(lsSubDomain, ""-"") = 0 Then
IsEmail = False
Exit Function
ElseIf Not IsNumeric(lsSubDomain)Then
IsEmail = False
Exit Function
End If

lnOctect = CInt(lsSubDomain)

If lnOctect > 255 Then
IsEmail = False
Exit Function
ElseIf lnOctect < 0 Then
IsEmail = False
Exit Function
End If

’ Look for private network settings
If lnIndex = 0 Then

’ Grab 2nd IP value
lnOctect2 = lsSubDomainArray(1)

If Len(lnOctect2) > 3 Then
IsEmail = False
Exit Function
ElseIf Not IsNumeric(lnOctect2)Then
IsEmail = False
Exit Function
End If

lnOctect2 = CInt(lnOctect2)

’ TCP/IP addresses reserved for ’private’ networks are:

’ 10.0.0.0 to 10.255.255.255
’ 172.16.0.0 to 172.31.255.255
’ 192.168.0.0 to 192.168.255.255

Select Case lnOctect

Case 10 ’ Private Network
IsEmail = False
Exit Function

Case 172
If lnOctect2 => 16 And lnOctect2 =< 31 Then
IsEmail = False
Exit Function
End If

Case 192 ’ Local Network
If lnOctect2 = 168 Then
IsEmail = False
Exit Function
End If

Case 127 ’ Local Machine
IsEmail = False
Exit Function

End Select

End If
’ End ’private’ network check
Else

If lnIndex = UBound(lsSubDomainArray, 1) Then

’ Last domain can have 3 characters max
If Len(lsSubDomain) > 3 Then
IsEmail = False
Exit Function
ElseIf Not InStr(lsSubDomain, ""-"") = 0 Then
IsEmail = False
Exit Function
End If

Else
’ Domain, sub domain can only have 22 characters max
If Len(lsSubDomain) > 22 Then
IsEmail = False
Exit Function
End If
End If
End If
Next

’ Check for valid characters in username
lnStart = 1
Do While lnStart <= Len(lsUserName)
If InStr(lsDOMAIN_CHARACTERS, Mid(lsUserName, lnStart, 1)) Then
lnStart = lnStart + 1
Else
IsEmail = False
Exit Function
End If
Loop

IsEmail = True
End Function
%>

Lewis Moten
Dernière mise à jour :

Commentaires

Ajouter un commentaire
Votre adresse de courriel ne sera pas publiée. * L'astérisque indique les champs obligatoires.
Votre évaluation du tutoriel

       Visites : 3490 - Pages vues : 4406
X

Trucsweb.com Connexion

Connexion

X

Trucsweb.com Mot de passe perdu

Connexion

X

Trucsweb.com Conditions générales

Conditions

Responsabilité

La responsabilité des Trucsweb.com ne pourra être engagée en cas de faits indépendants de sa volonté. Les informations mises à disposition sur ce site le sont uniquement à titre purement informatif et ne sauraient constituer en aucun cas un conseil ou une recommandation de quelque nature que ce soit.

Aucun contrôle n'est exercé sur les références et ressources externes, l'utilisateur reconnaît que les Trucsweb.com n'assume aucune responsabilité relative à la mise à disposition de ces ressources, et ne peut être tenue responsable quant à leur contenu.

Droit applicable et juridiction compétente

Les règles en matière de droit, applicables aux contenus et aux transmissions de données sur et autour du site, sont déterminées par la loi canadienne. En cas de litige, n'ayant pu faire l'objet d'un accord à l'amiable, seuls les tribunaux canadien sont compétents.

X

Trucsweb.com Trucsweb

X

Trucsweb.com Glossaire

X

Trucsweb.com Trucsweb

X

Trucsweb.com Trucsweb

Conditions

Aucun message!

Merci.

X
Aucun message!
X

Trucsweb.com Créer un compte

Créer un compte

.
@