ASP判断E-Mail的合法性,以及过滤邮箱字符

时间:2010-05-27 12:23:00 

函数名:chk_Email()

'返回值:布尔值(True为通过,False为未通过)

'参数:email(需要判断的email,类型:字符串)   Type_1(是否需要判断@之后的domain,类型:布尔值)

'Type_2(是否只能是特定域的E-Mail注册,类型:布尔值) Type_3(一个E-Mail是否只能注册一次,类型:布尔值)

 

Const C_maildomain=".com,.com.cn,.net,.net.cn,.org,.org.cn,.gov,.gov.cn,.edu,.edu.cn,.cn,.cc,.biz,.info" '电子邮件可接受的domain

Const C_Lockdomain="bit.edu.cn,loster.org" '特定的域

Function chk_Email(email,Type_1,Type_2,Type_3)
 Dim i,k
 Dim At
 Dim Email_1,Temp

 If email="" Then
  chk_Email=False
  Exit Function
 End If

 Email_1=Cstr(trim(email))

 If Len(Email_1)<5 Then
  chk_Email=False
  Exit Function
 End If

 At=False

 For i=1 To Len(Email_1)
  Temp=Mid(Email_1,i,1)
  If Temp="@" Then
   at=True
   Exit For
  End If
 Next

 If At=False Then
  Chk_Email=False
  Exit Function
 End If
 
 k=0

 For i=1 To Len(Email_1)
  Temp=Mid(Email_1,i,1)
  If Temp="." then
   k=k+1
  End If
 Next

 If k=0 Or k>2 Then
  Chk_Email=False
  Exit Function
 End If


 If Type_1=True Then

 For i=1 To Len(Email_1)
  Temp=Mid(Email_1,i,1)
  If Temp="@" Then
   k=i
   Exit For
  End If
 Next
 
 For i=k To Len(Email_1)
  Temp=Mid(Email_1,i,1)
   If Temp="." Then
    k=i
    Exit For
   End If
 Next

 Temp=""

 For i=k To Len(Email_1)
  Temp=Temp+Mid(Email_1,i,1)
 Next

 Temp=Cstr(Trim(Temp))
 At=False

 For i=0 To R_Reader(C_Maildomain,",")
  If Temp=Reader(i) Then
   At=True
   Exit For
  End If
 Next
 
 Erase Reader

 If At=False Then
  Chk_Email=False
  Exit Function
 End If
 
 End If

 If Type_2=True Then
  For i=1 To Len(Email_1)
   Temp=Mid(Email_1,i,1)
   If Temp="@" Then
    k=i
    Exit For
   End If
  Next

  Temp=""

  For i=k+1 To Len(Email_1)
   Temp=Temp+Mid(Email_1,i,1)
  Next

  Temp=Cstr(Trim(Temp))
  
  At=False
  For i=0 To R_Reader(C_Lockdomain,",")
   If Temp=Reader(i) Then
    At=True
    Exit For
   End If
  Next
   
   Erase Reader

  If At=False Then
   Chk_Email=False
   Exit Function
  End If
 End If
  
 If Type_3=True Then
  Dim j
  Call Greate_UserDb()
  Call Create_Rs("Select * from User_Basic_Info where User_Email='"&Email_1&"'",1,1,"User")
    If Rs.Bof=False Then
     Chk_email=False
     Call Close_Rs()
     Call Close_UserDb()
     Exit Function
    End If
  Call Close_Rs()
 Call Close_UserDb()
 End If
 chk_email=True
End Function

 

Dim User_Db,User_Driver
Dim User_Conn

User_Db="Data/userdata.mdb"

'建立User_conn的过程
Sub Greate_UserDb()
 User_Driver="driver={Microsoft Access Driver (*.mdb)}"
 User_Driver=User_Driver&";dbq="&server.mappath(User_Db)
 'Response.Write (User_Driver)
Set User_Conn = Server.CreateObject("ADODB.Connection")
 User_Conn.Open(User_Driver)
End Sub

'关闭User_conn的过程
Sub Close_UserDb()
 User_Conn.Close
 Set User_Conn=Nothing
End Sub

Dim Reader
Dim Rs

'读取常数,并将每个常数保存在reader数组中,参数:R_Str(常数串),F_Str(分隔符),返回值:Reader数组的下标
Function R_Reader(R_Str,F_Str)
 Dim i
 
 If R_Str="" Or F_Str="" Then
  Exit Function
 End If
 
 Reader=Split(R_Str,F_Str)
 
 For i=0 To Ubound(Reader,1)
  Reader(i)=Cstr(Trim(Reader(i)))
 Next
 R_Reader=Ubound(Reader,1)
End Function


标签:email,邮箱,asp
0
投稿

猜你喜欢

  • ipad上运行python的方法步骤

    2021-12-06 19:05:36
  • 微信小程序前端自定义分享的实现方法

    2024-05-02 16:13:35
  • Python 按字典dict的键排序,并取出相应的键值放于list中的实例

    2022-01-26 16:48:46
  • Apache DophinScheduler定时调度Python脚本的实现

    2021-06-23 15:02:54
  • 安装MSSql2005时 “以前的某个程序安装已在安装计算机上创建挂起” 的解决办法

    2024-01-22 08:49:39
  • 部署ASP.NET Core程序到Linux系统

    2024-05-02 17:19:54
  • Python检查ping终端的方法

    2023-04-16 07:03:37
  • php动态函数调用方法

    2023-11-15 00:18:30
  • oracle学习笔记(三)

    2012-01-05 19:28:42
  • Python Socket编程详细介绍

    2021-01-02 02:56:21
  • vantUI 获得piker选中值的自定义ID操作

    2024-04-10 13:48:42
  • python多线程semaphore实现线程数控制的示例

    2022-12-29 18:31:40
  • Python实战小项目之Mnist手写数字识别

    2023-01-20 23:24:56
  • Python深入浅出分析enum枚举类

    2022-07-07 15:09:14
  • centOS7安装MySQL数据库

    2024-01-16 21:58:07
  • python实现数通设备tftp备份配置文件示例

    2022-12-02 13:59:21
  • Python包装异常处理方法

    2022-03-13 12:08:42
  • python实现将pvr格式转换成pvr.ccz的方法

    2022-09-01 05:54:14
  • Python3 pandas.concat的用法说明

    2023-11-22 23:46:51
  • HTML在线编辑器的实现难点

    2010-06-26 12:58:00
  • asp之家 网络编程 m.aspxhome.com