asp制作中常用到的函数库集合

  ASP函数库

  <%

  '''' 函数目录 ''''

  ''''-----------------------------------------------''''

  '''' 函数ID:0001[截字符串] ''''

  '''' 函数ID:0002[过滤html] ''''

  '''' 函数ID:0003[打开任意数据表并显示表结构及内容]''''

  '''' 函数ID:0004[读取两种路径] ''''

  '''' 函数ID:0005[测试某个文件存在否] ''''

  '''' 函数ID:0006[删除某个文件] ''''

  '''' 函数ID:0007[判断目录是否存在] ''''

  '''' 函数ID:0008[创建目录] ''''

  '''' 函数ID:0009[删除目录] ''''

  '''' 函数ID:0010[指定目录的文件列表] ''''

  '''' 函数ID:0011[指定目录的目录列表] ''''

  '''' 函数ID:0012[创建文本文件] ''''

  '''' 函数ID:0013[读取文本文件] ''''

  '''' 函数ID:0014[检测ID是否为数字类型] ''''

  '''' 函数ID:0015[正则表达式测试] ''''

  '''' 函数ID:0016[获得执行程序的名称] ''''

  '''' 函数ID:0017[读取用户IP地址信息] ''''

  '''' 函数ID:0018[上传文件到指定目录并改文件名称] ''''

  '''' 函数ID:0019[过滤HTML脚本] ''''

  '''' 函数ID:0020[创建MsAccess数据库] ''''

  '''' 函数ID:0021[创建MsSQLServer数据库] ''''

  '''' 函数ID:0022[通过JMAIL发信] ''''

  '''' 函数ID:0023[测试组件是否安装] ''''

  '''' 函数ID:0024[上传文件的窗口] ''''

  '''' 函数ID:0025[取得数据库链接字串] ''''

  '''' 函数ID:0026[取得multipart/form-data形式上传文件]

  '''' 函数ID:0027[保存或查看上传到数据库中的数据,带调用上传窗口]

  '''' 函数ID:0028[取得图像的类型|宽|高] ''''

  '''' 函数ID:0029[将本地文件进行二进制分析,并保存到服务器的指定目录下]

  '''' 函数ID:0030[将本地数据表或库上传并导入到服务器数据库的表中]

  '''' 函数ID:0031[返回服务器信息] ''''

  '''' 函数ID:0032[产生20位长度的唯一标识ID] ''''

  '''' 函数ID:0033[用于左填充指定数量的字符] ''''

  '''' 函数ID:0034[用于右填充指定数量的字符] ''''

  '''' 函数ID:0035[格式化时间(显示)] ''''

  '''' 函数ID:0036[测试数据库是否存在] ''''

  '''' 函数ID:0037[测试数据库中的表是否存在] ''''

  '''' 函数ID:0038[在线HTML编辑器] ''''

  '''' 函数ID:0039[判断是否奇数] ''''

  '''' 函数ID:0040[生成验证码图像BMP] ''''

  '''' 函数ID:0041[生成随机密码] ''''

  '''' 函数ID:0042[字符加解密] ''''

  '''' 函数ID:0043[解密字符加解密] ''''

  '''' 函数ID:0044[创建数据表] ''''

  '''' 函数ID:0045[在数据库中插入字段值] ''''

  '''' 函数ID:0046[Cookie防乱码写入时用] ''''

  '''' 函数ID:0047[Cookie防乱码读出时用] ''''

  '''' 函数ID:0048[检测用户名和密码是否正确] ''''

  '''' 函数ID:0049[生成时间的整数] ''''

  '''' 函数ID:0050[获得栏目的所有子栏目字符串并用","隔开]

  '''' ''''

  '''' ''''

  '''' ''''

  '**************************************************''''

  '函数ID:0001[截字符串]

  '函数名:SubstZFC

  '作 用:截字符串,汉字一个算两个字符,英文算一个字符

  '参 数:str ----原字符串

  ' strlen ----截取长度

  '返回值:截取后的字符串

  '**************************************************

  Public Function SubstZFC(ByVal str, ByVal strlen)

  If str = "" Then

  SubstZFC = ""

  Exit Function

  End If

  Dim l, t, c, i, strTemp

  str = Replace(Replace(Replace(Replace(str, " ", " "), """, Chr(34)), ">", ">"), "<", "<")

  l = Len(str)

  t = 0

  strTemp = str

  strlen = CLng(strlen)

  For i = 1 To l

  c = Abs(Asc(Mid(str, i, 1)))

  If c > 255 Then

  t = t + 2

  Else

  t = t + 1

  End If

  If t >= strlen Then

  strTemp = Left(str, i)

  Exit For

  End If

  Next

  SubstZFC = Replace(Replace(Replace(Replace(strTemp, " ", " "), Chr(34), """), ">", ">"), "<", "<")

  End Function

  '**************************************************

  '函数ID:0002[过滤html]

  '函数名:GlHtml

  '作 用:过滤html 元素

  '参 数:str ---- 要过滤字符

  '返回值:没有html 的字符

  '**************************************************

  Public Function GlHtml(ByVal str)

  If IsNull(str) Or Trim(str) = "" Then

  GlHtml = ""

  Exit Function

  End If

  Dim re

  Set re = New RegExp

  re.IgnoreCase = True

  re.Global = True

  re.Pattern = "(\<.[^\<]*\>)"

  str = re.Replace(str, " ")

  re.Pattern = "(\<\/[^\<]*\>)"

  str = re.Replace(str, " ")

  Set re = Nothing

  str = Replace(str, "'", "")

  str = Replace(str, Chr(34), "")

  GlHtml = str

  End Function

  '**************************************************

  '函数ID:0003[打开任意数据表并显示表结构及内容]

  '函数名:OpOtherDB

  '作 用:打开任意数据表并显示表结构及内容

  '参 数:DBtheStr ---- 要打开表的数据库链接字串

  '参 数:Opentdname ---- 要打开表名

  '返回值:显示表结构及内容

  '**************************************************

  Public Function OpOtherDB(ByVal DBtheStr,ByVal Opentdname)

  Response.write "<table border='0' width='100%' cellspacing='0' cellpadding='0'>" & vbCrlf

  Set Opdb_Conn=server.createobject("ADODB.Connection")

  Set Opdb_Rs =server.createobject("ADODB.Recordset")

  Opdb_Conn.open DBtheStr

  Opdb_sql_str="select * from "&Opentdname

  Opdb_Rs.open Opdb_Sql_Str,Opdb_Conn,1,1

  Nfieldnumber=Opdb_Rs.Fields.count

  If Nfieldnumber >0 then

  Response.write "<tr>" & vbCrlf

  For i=0 to (Nfieldnumber-1)

  Response.write "<td style='border-style: ridge; border-width: 1' bgcolor='#E1E1E1' valign='middle' align='center'>"

  Response.write Trim(Opdb_Rs.Fields(i).Name)

  Response.write "</td>" & vbCrlf

  Next

  temptbi=0

  Do While Not Opdb_Rs.Eof

  Response.write "</tr>" & vbCrlf

  For i=0 to (Nfieldnumber-1)

  If (temptbi<2) Then

  Response.write "<td style='border-style: ridge; border-width: 1' bgcolor='#F6F6F6' valign='middle'>"

  Response.write Trim(Opdb_Rs.Fields(i))

  Response.write "</td>" & vbCrlf

  temptbi=temptbi+1

  Else

  Response.write "<td style='border-style: ridge; border-width: 1' valign='middle'>"

  Response.write Trim(Opdb_Rs.Fields(i))

  Response.write "</td>" & vbCrlf

  If temptbi>=3 Then

  temptbi=0

  Else

  temptbi=temptbi+1

  End If

  End If

  Next

  Opdb_Rs.MoveNext

  Response.write "</tr>" & vbCrlf

  Loop

  End If

  Opdb_Rs.Close

  Opdb_Conn.Close

  Set Opdb_Rs = Nothing

  Set Opdb_Conn=Nothing

  Response.write "</table>" & vbCrlf

  End function

  '**************************************************

  '函数ID:0004[读取两种路径]

  '函数名:Readsyspath

  '作 用:读取路径

  '参 数:lx ---- 0:服务器IP加路径 1:服务物理路径

  '返回值:路径字串

  '**************************************************

  Public Function Readsyspath(ByVal lx)

  Dim templj,aryTemp,newpath

  templj=""

  newpath=""

  If lx=0 Then

  templj="http://"&Request("SERVER_NAME")&Request("PATH_INFO")

  aryTemp = Split(templj,"/")

  Else

  templj=Request("PATH_TRANSLATED")

  aryTemp = Split(templj,"\")

  End If

  For i = LBound(aryTemp) To UBound(aryTemp)-1

  If lx=0 Then

  newpath=newpath&aryTemp(i)&"/"

  Else

  newpath=newpath&aryTemp(i)&"\"

  End If

  Next

  Readsyspath=newpath

  End Function

  '**************************************************

  '函数ID:0005[测试某个文件存在否]

  '函数名:CheckFile

  '作 用:测试某个文件存在否

  '参 数:ckFilename ---- 被测试的文件名(包括路径)

  '返回值:文件存在返回True,否则False

  '**************************************************

  Public Function CheckFile(ByVal ckFilename)

  Dim M_fso

  CheckFile=False

  Set M_fso = CreateObject("Scripting.FileSystemObject")

  If M_fso.FileExists(ckFilename) Then

  CheckFile=True

  End If

  Set M_fso = Nothing

  End Function

  '**************************************************

  '函数ID:0006[删除某个文件]

  '函数名:DelFile

  '作 用:删除某个文件

  '参 数:dFilename ---- 被删除的文件名(包括路径)

  '返回值:文件删除返回True,否则False

  '**************************************************

  Public Function DelFile(ByVal dFilename)

  Dim M_fso

  DelFile=False

  Set M_fso = CreateObject("Scripting.FileSystemObject")

  If M_fso.FileExists(dFilename) Then

  M_fso.DeleteFile(dFilename)

  DelFile=True

  End If

  Set M_fso = Nothing

  End Function

  '**************************************************

  '函数ID:0007[判断目录是否存在]

  '函数名:CheckDir

  '作 用:判断目录是否存在

  '参 数:ckDirname ---- 目录名(包括路径)

  '返回值:目录存在返回True,否则False

  '**************************************************

  Public Function CheckDir(ByVal ckDirname)

  Dim M_fso

  CheckDir=False

  Set M_fso = CreateObject("Scripting.FileSystemObject")

  If (M_fso.FolderExists(ckDirname)) Then

  CheckDir=True

  End If

  Set M_fso = Nothing

  End Function

  '**************************************************

  '函数ID:0008[创建目录]

  '函数名:CreateDir

  '作 用:创建目录

  '参 数:crDirname ---- 目录名(包括路径)

  '返回值:目录创建成功返回True,否则False

  '**************************************************

  Public Function CreateDir(ByVal crDirname)

  Dim M_fso

  CreateDir=False

  Set M_fso = CreateObject("Scripting.FileSystemObject")

  If (M_fso.FolderExists(crDirname)) Then

  CreateDir=False

  Else

  M_fso.CreateFolder(crDirname)

  CreateDir=True

  End If

  Set M_fso = Nothing

  End Function

  '**************************************************

  '函数ID:0009[删除目录]

  '函数名:DelDir

  '作 用:删除目录

  '参 数:DlDirname ---- 目录名(包括路径)

  '返回值:目录删除成功返回True,否则False

  '**************************************************

  Public Function DelDir(ByVal DlDirname)

  Dim M_fso

  DelDir=False

  Set M_fso = CreateObject("Scripting.FileSystemObject")

  If (M_fso.FolderExists(DlDirname)) Then

  M_fso.DeleteFolder(DlDirname)

  DelDir=True

  End If

  Set M_fso = Nothing

  End Function

  '**************************************************

  '函数ID:0010[指定目录的文件列表]

  '函数名:ListFiles

  '作 用:指定目录的文件列表

  '参 数:Dirname ---- 目录名(包括路径)

  '返回值:文件列表字符串,之间用“|”相隔

  '**************************************************

  Public Function ListFiles(ByVal Dirname)

  Dim M_fso,fNS,fLS,Fnames,FnamesN

  Set M_fso = CreateObject("Scripting.FileSystemObject")

  If (M_fso.FolderExists(Dirname)) Then

  Set fNS = M_fso.GetFolder(Dirname)

  Set fLS=fNS.Files

  For Each FnamesN in fLS

  Fnames=Fnames & FnamesN.name

  Fnames=Fnames & "|"

  Next

  ListFiles=Fnames

  End If

  Set M_fso = Nothing

  End Function

  '**************************************************

  '函数ID:0011[指定目录的目录列表]

  '函数名:ListDirs

  '作 用:指定目录的目录列表

  '参 数:Dirname ---- 目录名(包括路径)

  '返回值:目录列表字符串,之间用“|”相隔

  '**************************************************

  Public Function ListDirs(ByVal Dirname)

  Dim M_fso,fNS,fLS,Fnames,FnamesN

  Set M_fso = CreateObject("Scripting.FileSystemObject")

  If (M_fso.FolderExists(Dirname)) Then

  Set fNS = M_fso.GetFolder(Dirname)

  Set fLS=fNS.SubFolders

  For Each FnamesN in fLS

  Fnames=Fnames & FnamesN.name

  Fnames=Fnames & "|"

  Next

  ListDirs=Fnames

  End If

  Set M_fso = Nothing

  End Function

  '**************************************************

  '函数ID:0012[创建文本文件]

  '函数名:WritTextFile

  '作 用:创建文本文件

  '参 数:Fname ---- 文本文件名称(包括路径)

  '参 数:WritString ---- 写入的内容

  '返回值:创建成功返回True,否则False

  '**************************************************

  Public Function WritTextFile(ByVal Fname,ByVal WritString)

  Dim M_fso,FnameN

  WritTextFile=False

  Set M_fso = CreateObject("Scripting.FileSystemObject")

  Set FnameN= M_fso.OpenTextFile(Fname,2,True)

  FnameN.Write WritString

  FnameN.Close

  Set M_fso = Nothing

  WritTextFile=True

  End Function

  '**************************************************

  '函数ID:0013[读取文本文件]

  '函数名:ReadTextFile

  '作 用:读取文本文件

  '参 数:Fname ---- 文本文件名称(包括路径)

  '返回值:返回读取的文本内容

  '**************************************************

  Public Function ReadTextFile(ByVal Fname)

  Dim M_fso,FnameN,Fnr

  ReadTextFile=""

  Set M_fso = CreateObject("Scripting.FileSystemObject")

  Set FnameN= M_fso.OpenTextFile(Fname,1,True)

  Fnr=FnameN.ReadAll

  FnameN.Close

  Set M_fso = Nothing

  ReadTextFile=Fnr

  End Function

  '**************************************************

  '函数ID:0014[检测ID是否为数字类型]

  '函数名:JCID

  '作 用:检测ID是否为数字类型

  '参 数:ParaValue ---- 被检测的ID值

  '返回值:返回ID值,如果不为数字类型返回0

  '**************************************************

  Public Function JCID(ByVal ParaValue)

  If ((Not isNumeric(ParaValue)) OR (Trim(ParaValue)="")) Then

  JCID=0

  Else

  JCID=ParaValue

  End If

  End function

  '**************************************************

  '函数ID:0015[正则表达式测试]

  '函数名:CheckExp

  '作 用:正则表达式测试

  '参 数:patrn ---- 正则表达式

  '参 数:strng ---- 要测试的字符串

  '返回值:测试如果成立返回 True 否则 False

  '例 CheckExp("(\<.[^\<]*\>)","<br>")

  '**************************************************

  Public Function CheckExp(ByVal patrn, ByVal strng)

  Dim regEx, retVal

  Set regEx = New RegExp

  regEx.Pattern = patrn

  regEx.IgnoreCase = False

  retVal = regEx.Test(strng)

  CheckExp = retVal

  End Function

  '**************************************************

  '函数ID:0016[获得执行程序的名称]

  '函数名:GT_the_proname

  '作 用:获得执行程序的名称

  '参 数:

  '返回值:返回执行程序的名称

  '**************************************************

  Public Function GT_the_proname()

  Dim fu_name,temp,tempsiz

  temp=Request.ServerVariables("PATH_INFO")

  fu_name=Split(temp, "/", -1, 1)

  tempsiz=UBound(fu_name)

  GT_the_proname=fu_name(tempsiz)

  End function

  '**************************************************

  '函数ID:0017[读取用户IP地址信息]

  '函数名:Readusip

  '作 用:读取用户IP地址信息

  '参 数:

  '返回值:返回用户IP地址

  '**************************************************

  Public Function Readusip()

  Dim strIPAddr

  If Request.ServerVariables("HTTP_X_FORWARDED_FOR") = "" OR InStr(Request.ServerVariables("HTTP_X_FORWARDED_FOR"), "unknown") > 0 Then

  strIPAddr = Request.ServerVariables("REMOTE_ADDR")

  ElseIf InStr(Request.ServerVariables("HTTP_X_FORWARDED_FOR"), ",") > 0 Then

  strIPAddr = Mid(Request.ServerVariables("HTTP_X_FORWARDED_FOR"), 1, InStr(Request.ServerVariables("HTTP_X_FORWARDED_FOR"), ",")-1)

  ElseIf InStr(Request.ServerVariables("HTTP_X_FORWARDED_FOR"), ";") > 0 Then

  strIPAddr = Mid(Request.ServerVariables("HTTP_X_FORWARDED_FOR"), 1, InStr(Request.ServerVariables("HTTP_X_FORWARDED_FOR"), ";")-1)

  Else

  strIPAddr = Request.ServerVariables("HTTP_X_FORWARDED_FOR")

  End If

  Readusip = Trim(Mid(strIPAddr, 1, 30))

  End Function

  '**************************************************

  '函数ID:0018[无组件上传文件到指定目录并改文件名称]

  '函数名:UpFsRn

  '作 用:无组件上传文件到指定目录并更改文件名称

  '参 数:RetSize--- 上传限止大小(单位是M)

  '参 数:Fdir ---- 目标路径

  '参 数:Objwj ---- 目标文件名称

  '返回值:如果成功 True 否则 False

  '例 UpFsRn(10,Readsyspath(1)&"zfkhauto","test.txt")

  '使用表单提取文件 <form method='POST' action='function.asp' enctype='multipart/form-data'><input type='file' name='T1'><input type='submit' value='提交' name='B1'></form>

  '**************************************************

  Public Function UpFsRn(ByVal RetSize,ByVal Fdir,ByVal Objwj)

  UpFsRn=False

  Dim oUpStream,oStream,formsize,Formdata,strFileName,strFileDir,ObjAllPath,datastart,dataend

  strFileDir = Fdir

  strFileName = Swj

  ObjAllPath = ""

  If Right(strFileDir,1)<>"\" Then strFileDir=strFileDir&"\"

  ObjAllPath =strFileDir&Objwj

  If CheckFile(ObjAllPath) Then DelFile(ObjAllPath)

  formsize=Request.TotalBytes

  if (formsize<=(RetSize*1024*1024)) then

  Formdata=Request.BinaryRead(formsize)

  Pos_ts=LenB(getByteString(Chr(13) & Chr(10) & Chr(13) & Chr(10)))

  Pos_b=InstrB(Formdata,getByteString(Chr(13) & Chr(10) & Chr(13) & Chr(10)))+Pos_ts

  nFormdata=MidB(Formdata,Pos_b)

  Pos_ts=InstrB(nFormdata,getByteString(Chr(13) & Chr(10) & "--"))

  nnFormdata=MidB(nFormdata,Pos_ts)

  Pos_e=LenB(Formdata)-LenB(nnFormdata)-Pos_b+1

  datastart =Pos_b

  dataend=Pos_e

  set oUpStream = Server.CreateObject("adodb.stream")

  oUpStream.Type = 1

  oUpStream.Mode = 3

  oUpStream.Open

  set oStream = Server.CreateObject("adodb.stream")

  oStream.Type = 1

  oStream.Mode = 3

  oStream.Open

  oUpStream.Write Formdata

  oUpStream.position=datastart-1

  oUpStream.copyto oStream,dataend

  oStream.SaveToFile ObjAllPath,2

  oStream.Close

  set oStream=nothing

  UpFsRn=True

  End If

  End function

  '**************************************************

  '函数ID:0019[过滤HTML脚本]

  '函数名:FilterJS

  '作 用:过滤HTML脚本

  '参 数:strHTML ---- 被检测的HTML字串

  '返回值:返回过滤后的HTML

  '**************************************************

  Function FilterJS(ByVal strHTML)

  Dim objReg,strContent

  If IsNull(strHTML) OR strHTML="" Then Exit Function

  Set objReg=New RegExp

  objReg.IgnoreCase =True

  objReg.Global=True

  objReg.Pattern="(&#)"

  strContent=objReg.Replace(strHTML,"")

  objReg.Pattern="(function|meta|value|window\.|script|js:|about:|file:|Document\.|vbs:|frame|cookie)"

  strContent=objReg.Replace(strContent,"")

  objReg.Pattern="(on(finish|mouse|Exit=|error|click|key|load|focus|Blur))"

  strContent=objReg.Replace(strContent,"")

  FilterJS=strContent

  strContent=""

  Set objReg=Nothing

  End Function

  '**************************************************

  '函数ID:0020[创建MsAccess数据库]

  '函数名:CrDb_MsAccess

  '作 用:创建MsAccess数据库

  '参 数:DbPath ---- 目标目录信息

  '参 数:DbFileName ---- 目标库文件名称

  '参 数:DbUpwd ---- 目标库打开密码

  '返回值:建立成功返回 True 否则 False

  '**************************************************

  Public Function CrDb_MsAccess(ByVal DbPath,ByVal DbFileName,ByVal DbUpwd)

  CrDb_MsAccess=False

  On Error GoTo 0

  On Error Resume Next

  DIM fxztxt,fu_fu_db_str,fu_db_str

  fxztxt=Chr(60)&"%Response.end()%"&Chr(62)

  If Right(DbPath,1)<>"\" Then DbPath=DbPath & "\"

  fu_fu_db_str="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="&DbPath&"temp.mdb;"

  fu_db_str ="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="&DbPath&DbFileName&";Jet OLEDB:Database Password="&DbUpwd&";"

  Set fu_Ca = Server.CreateObject("ADOX.Catalog")

  fu_Ca.Create fu_fu_db_str

  Set fu_Ca = Nothing

  Set fu_Je = Server.CreateObject("JRO.JetEngine")

  fu_Je.CompactDatabase fu_fu_db_str,fu_db_str

  Set fu_fso = CreateObject("Scripting.FileSystemObject")

  fu_fso.DeleteFile(DbPath&"temp.mdb")

  Set fu_Je = Nothing

  Set fu_fso = Nothing

  set fu_Conn =server.createobject("ADODB.Connection")

  set fu_Rs =server.createobject("ADODB.Recordset")

  fu_Conn.open fu_db_str

  fu_Sql_Str="CREATE TABLE [0] ([0] Text DEFAULT Notxt NOT NULL,[11] int IDENTITY (1, 1) NOT NULL PRIMARY KEY)"

  fu_Conn.Execute(fu_Sql_Str)

  fu_Sql_Str="Select * From [0]"

  fu_Rs.open fu_Sql_Str,fu_Conn,1,3

  fu_Rs.addnew

  fu_Rs("0")=fxztxt

  fu_Rs.update

  fu_Rs.Close

  fu_Conn.Close

  Set fu_Rs = Nothing

  Set fu_Conn = Nothing

  If Err.Number = 0 Then

  CrDb_MsAccess=True

  End If

  On Error GoTo 0

  End function

  '**************************************************

  '函数ID:0021[创建MsSQLServer数据库]

  '函数名:CrDb_MsSQLServer

  '作 用:创建MsSQLServer数据库

  '参 数:DbIp ---- 数据库所在IP或主机名称

  '参 数:DbSamc ---- 数据库超管用户名称

  '参 数:DbSapwd---- 数据库超管用户口令

  '参 数:DbName ---- 新建数据库名称

  '参 数:DbUpmc ---- 新建数据库所属用户名称

  '参 数:DbUpwd ---- 新建数据库所属用户密码

  '返回值:建立成功返回 True 否则 False

  '**************************************************

  Public Function CrDb_MsSQLServer(ByVal DbIp,ByVal DbSamc,ByVal DbSapwd,ByVal DbName,ByVal DbUpmc,ByVal DbUpwd)

  CrDb_MsSQLServer=False

  On Error GoTo 0

  On Error Resume Next

  DIM fu_Sa_Str,fu_Ua_Str,fu_Conn,fu_Rs,fu_Sql_Str,fxztxt

  fxztxt=Chr(60)&"%Response.end()%"&Chr(62)

  fu_Sa_Str ="DRIVER=SQL Server;UID="&DbSamc&";DATABASE=master;SERVER="&DbIp&";PWD="&DbSapwd&";"

  fu_Ua_Str ="DRIVER=SQL Server;UID="&DbUpmc&";DATABASE="&DbName&";SERVER="&DbIp&";PWD="&DbUpwd&";"

  Set fu_Conn = Server.CreateObject("ADODB.Connection")

  fu_Conn.Open fu_Sa_Str

  fu_Conn.Execute "CREATE DATABASE " &DbName

  fu_Conn.Close

  fu_DB_Conn_Str="DRIVER=SQL Server;UID="&DbSamc&";DATABASE="&DbName&";SERVER="&DbIp&";PWD="&DbSapwd&";"

  fu_Conn.Open fu_DB_Conn_Str

  fu_Sql_Str="EXEC sp_addlogin '"&DbUpmc&"','"&DbUpwd&"','"&DbName&"'"

  fu_Conn.Execute fu_Sql_Str

  fu_Sql_Str="EXEC sp_grantdbaccess '"&DbUpmc&"'"

  fu_Conn.Execute fu_Sql_Str

  fu_Sql_Str="EXEC sp_addrolemember 'db_owner', '"&DbUpmc&"'"

  fu_Conn.Execute fu_Sql_Str

  fu_Sql_Str="EXEC sp_defaultdb "&DbUpmc&","&DbName

  fu_Conn.Execute fu_Sql_Str

  fu_Conn.Close

  fu_Conn.open fu_Ua_Str

  fu_Sql_Str="CREATE TABLE [0] ([0] Text DEFAULT ('Notxt') NOT NULL,[11] int IDENTITY (1, 1) NOT NULL PRIMARY KEY)"

  fu_Conn.Execute fu_Sql_Str

  Set fu_Rs=server.createobject("ADODB.Recordset")

  fu_Sql_Str="Select * From [0]"

  fu_Rs.open fu_Sql_Str,fu_Conn,1,3

  fu_Rs.addnew

  fu_Rs("0")=fxztxt

  fu_Rs.update

  fu_Rs.Close

  fu_Conn.Close

  Set fu_Rs = Nothing

  Set fu_Conn=Nothing

  If Err.Number = 0 Then

  CrDb_MsSQLServer=True

  End If

  On Error GoTo 0

  End function

  '**************************************************

  '函数ID:0022[通过JMAIL发信]

  '函数名:MSMail

  '作 用:通过JMAIL发信

  '参 数:subject ---- 邮件的标题

  '参 数:mailaddress ---- 邮件服务器地址

  '参 数:senderName ---- 发件人名称

  '参 数:email ---- 收件人E-MAIL地址

  '参 数:content ---- 邮件内容

  '参 数:fromer ---- 发件人E-MAIL地址

  '参 数:serEmailUser ---- 邮件服务器权限用户名

  '参 数:serEmailPass ---- 邮件服务器权限用户密码

  '返回值:发送成功返回 True 否则 False

  '示 例:MSMail("test","smtp.163.com","mzy","[email protected]","test","[email protected]","mzymcm","abcmzy1029abc")

  '**************************************************

  Public Function MSMail(ByVal subject, ByVal mailaddress, ByVal senderName, ByVal email, ByVal content, ByVal fromer, ByVal serEmailUser, ByVal serEmailPass)

  dim JmailMsg

  MSMail=False

  set JmailMsg=server.createobject("jmail.message")

  JmailMsg.mailserverusername=serEmailUser

  JmailMsg.mailserverpassword=serEmailPass

  JmailMsg.addrecipient email

  JmailMsg.from=fromer

  JmailMsg.fromname=senderName

  JmailMsg.charset="gb2312"

  JmailMsg.logging=true

  JmailMsg.silent=true

  JmailMsg.subject=Subject

  JmailMsg.body=Server.HTMLEncode(content)

  JmailMsg.htmlbody=content

  if not JmailMsg.send(mailaddress) then

  MSMail=False

  else

  MSMail=True

  end if

  JmailMsg.close

  set JmailMsg=nothing

  End function

  '**************************************************

  '函数ID:0023[测试组件是否安装]

  '函数名:IsObjInstalled

  '作 用:测试组件是否安装

  '参 数:strClassString ---- 组件名称或标识字串

  '返回值:测试成功返回 True 否则 False

  '示 例:IsObjInstalled("JMAIL.Message")

  '**************************************************

  Public Function IsObjInstalled(ByVal strClassString)

  On Error Resume Next

  IsObjInstalled = False

  Err = 0

  Dim xTestObj

  Set xTestObj = Server.CreateObject(strClassString)

  If 0 = Err Then IsObjInstalled = True

  Set xTestObj = Nothing

  Err = 0

  End Function

  '**************************************************

  '函数名:GetObjVer

  '作 用:返回组件版本信息

  '参 数:strClassString ---- 组件名称或标识字串

  '返回值:返回组件版本信息字串

  '示 例:GetObjVer("JMAIL.Message")

  '**************************************************

  Public Function GetObjVer(ByVal strClassString)

  On Error Resume Next

  GetObjVer=""

  Err = 0

  Dim xTestObj

  Set xTestObj = Server.CreateObject(strClassString)

  If 0 = Err Then GetObjVer=xtestobj.version

  Set xTestObj = Nothing

  Err = 0

  End Function

  '**************************************************

  '函数名:ListObjInfo

  '作 用:列出组件安装信息

  '参 数: ----

  '返回值:列出组件安装信息

  '示 例:ListObjInfo()

  '**************************************************

  Public Function ListObjInfo()

  Dim TempBs,TempBsXX,TempObjType,tmpObjs

  TempBs="×"

  TempBsXX=""

  TempObjType=""

  tmpObjs=""

  tmpObjs=tmpObjs& "JMail.Message|"

  tmpObjs=tmpObjs& "ADODB.Stream|"

  tmpObjs=tmpObjs& "MSWC.AdRotator|"

  tmpObjs=tmpObjs& "MSWC.BrowserType|"

  tmpObjs=tmpObjs& "MSWC.NextLink|"

  tmpObjs=tmpObjs& "MSWC.Tools|"

  tmpObjs=tmpObjs& "MSWC.Status|"

  tmpObjs=tmpObjs& "MSWC.Counters|"

  tmpObjs=tmpObjs& "MSWC.PermissionChecker|"

  tmpObjs=tmpObjs& "Scripting.FileSystemObject|"

  tmpObjs=tmpObjs& "adodb.connection|"

  tmpObjs=tmpObjs& "SoftArtisans.FileUp|"

  tmpObjs=tmpObjs& "SoftArtisans.FileManager|"

  tmpObjs=tmpObjs& "CDONTS.NewMail|"

  tmpObjs=tmpObjs& "Persits.MailSender|"

  tmpObjs=tmpObjs& "LyfUpload.UploadFile|"

  tmpObjs=tmpObjs& "Persits.Upload.1|"

  tmpObjs=tmpObjs& "w3.upload|"

  tmpObjs=Split(tmpObjs,"|")

  Response.write "<center><table border='1' bordercolor='#000000' cellspacing='0' cellpadding='0' style='font-size: 9pt;"">宋体'><tr><td width='33%' valign='middle' align='center' style='border-left: 1 solid #808080; border-right: 1 solid #FFFFFF; border-top: 1 solid #FFFFFF; border-bottom: 1 solid #808080; padding-left: 2; padding-right: 2; padding-top: 1; padding-bottom: 1'>组件标识</td><td width='33%' valign='middle' align='center' style='border-left: 1 solid #808080; border-right: 1 solid #FFFFFF; border-top: 1 solid #FFFFFF; border-bottom: 1 solid #808080; padding-left: 2; padding-right: 2; padding-top: 1; padding-bottom: 1'>√|×</td><td width='34%' valign='middle' align='center' style='border-left: 1 solid #808080; border-right: 1 solid #FFFFFF; border-top: 1 solid #FFFFFF; border-bottom: 1 solid #808080; padding-left: 2; padding-right: 2; padding-top: 1; padding-bottom: 1'>版本</td></tr>" & vbCrlf

  For i = LBound(tmpObjs) To UBound(tmpObjs)

  If Trim(tmpObjs(i))<>"" Then

  If IsObjInstalled(tmpObjs(i)) Then

  TempObjType=tmpObjs(i)

  TempBs="√"

  TempBsXX=GetObjVer(tmpObjs(i))

  If TempBsXX="" Then TempBsXX=" "

  Else

  TempObjType="<font color='#800000'>"&tmpObjs(i)&"</font>"

  TempBs="<font color='#800000'>×</font>"

  TempBsXX=" "

  End If

  Response.write "<tr>" & vbCrlf

  Response.write "<td valign='middle' style='border-left: 1 solid #808080; border-right: 1 solid #FFFFFF; border-top: 1 solid #FFFFFF; border-bottom: 1 solid #808080; padding-left: 2; padding-right: 2; padding-top: 1; padding-bottom: 1'>"&TempObjType&"</td>" & vbCrlf

  Response.write "<td valign='middle' align='center' style='border-left: 1 solid #808080; border-right: 1 solid #FFFFFF; border-top: 1 solid #FFFFFF; border-bottom: 1 solid #808080; padding-left: 2; padding-right: 2; padding-top: 1; padding-bottom: 1'>"&TempBs&"</td>" & vbCrlf

  Response.write "<td valign='middle' align='center' style='border-left: 1 solid #808080; border-right: 1 solid #FFFFFF; border-top: 1 solid #FFFFFF; border-bottom: 1 solid #808080; padding-left: 2; padding-right: 2; padding-top: 1; padding-bottom: 1'>"&TempBsXX&"</td>" & vbCrlf

  Response.write "</tr>" & vbCrlf

  End If

  Next

  Response.write "</table></center>" & vbCrlf

  End Function

  '**************************************************

  '函数ID:0024[上传文件的窗口]

  '函数名:PosImageWin

  '作 用:上传选择文件窗口,可自动提取文件名及类型

  '参 数:PfUrlstr ---- 处理二进制文件信息的URL地址

  '返回值:网页HTML文件

  '示 例:库结构例子 CREATE TABLE [IMAGES] ([ID] int IDENTITY (1,1) NOT NULL PRIMARY KEY,[MC] varchar(50),[LX] varchar(20),[MEM] Text,[IMGS] image)

  '**************************************************

  Public Function PosImageWin(ByVal PfUrlstr)

  PosImageWin=""

  PosImageWin=PosImageWin & "<center><table border='0' width='0' cellspacing='0' cellpadding='0' style='font-size: 9pt'>" & vbCrlf

  PosImageWin=PosImageWin & "<SCRIPT LANGUAGE=javascript>"&vbCrlf

  PosImageWin=PosImageWin & "function ckfilelx(){"&vbCrlf

  PosImageWin=PosImageWin & "tempwjm=POFile.ImageFs.value;"&vbCrlf

  PosImageWin=PosImageWin & "fgwjm=tempwjm.split('.');"&vbCrlf

  PosImageWin=PosImageWin & "newwjm=fgwjm.reverse();"&vbCrlf

  PosImageWin=PosImageWin & "POMem.ImageType.value=newwjm[0].toUpperCase();"&vbCrlf

  PosImageWin=PosImageWin & "tempwjm=newwjm[1].toUpperCase();"&vbCrlf

  PosImageWin=PosImageWin & "fgwjm=tempwjm.split('\\');"&vbCrlf

  PosImageWin=PosImageWin & "newwjm=fgwjm.reverse();"&vbCrlf

  PosImageWin=PosImageWin & "POMem.ImageName.value=newwjm[0].toUpperCase();"&vbCrlf

  PosImageWin=PosImageWin & "POMem.ImageReadme.value=newwjm[0].toUpperCase();"&vbCrlf

  PosImageWin=PosImageWin & "}"&vbCrlf

  PosImageWin=PosImageWin & "function Reedit(){POFile.reset();POMem.reset();}"&vbCrlf

  PosImageWin=PosImageWin & "function PostDo(){if (POFile.ImageFs.value==''){alert('没有选择文件哟!');}else{bc.innerHTML='正在上传,请稍后...';POFile.action=POFile.action+'&mc='+POMem.ImageName.value+'&lx='+POMem.ImageType.value+'&mem='+POMem.ImageReadme.value;bc.style.visibility='visible';ReEd.disabled=true;PoSe.disabled=true;POFile.submit();POFile.ImageFs.disabled=true;}}"&vbCrlf

  PosImageWin=PosImageWin & "</SCRIPT>"&vbCrlf

  PosImageWin=PosImageWin & "<tr><form method='POST' name='POFile' enctype='multipart/form-data' ACTION='"&PfUrlstr&"' target='tempa'><td width='100%' valign='middle'>" & vbCrlf

  PosImageWin=PosImageWin & "选择文件:<input type='file' name='ImageFs' ONCHANGE='ckfilelx();' style='font-size: 9pt;width:300;'>" & vbCrlf

  PosImageWin=PosImageWin & "</td></form></tr>" & vbCrlf

  PosImageWin=PosImageWin & "<tr><form method='POST' name='POMem'><td width='100%' valign='middle'>" & vbCrlf

  PosImageWin=PosImageWin & "文件ID号:<input type='text' name='ImageID' ReadOnly style='font-size: 9pt;width:300;'><br>" & vbCrlf

  PosImageWin=PosImageWin & "文件名称:<input type='text' name='ImageName' style='font-size: 9pt;width:300;'><br>" & vbCrlf

  PosImageWin=PosImageWin & "文件类型:<input type='text' name='ImageType' ReadOnly style='font-size: 9pt;width:300;'><br>" & vbCrlf

  PosImageWin=PosImageWin & "文件介绍:<textarea rows='8' name='ImageReadme' cols='20' style='font-size: 9pt;width:300;'>还没有</textarea>" & vbCrlf

  PosImageWin=PosImageWin & "</td></form></tr>" & vbCrlf

  PosImageWin=PosImageWin & "<tr><td width='100%' valign='middle' align='center'>" & vbCrlf

  PosImageWin=PosImageWin & "<input type='button' value='重置' name='ReEd' OnClick='Reedit();'>  <input type='button' value='上传' name='PoSe' OnClick='PostDo();'>" & vbCrlf

  PosImageWin=PosImageWin & "</td></tr></table></center><div id='bc' name='bc' style='position: absolute; left: 45%; top:40%; z-index: 0;background-color: #EAEAEA;visibility: hidden;' valign='middle' align='center'></div>" & vbCrlf

  PosImageWin=PosImageWin & "<iframe src='' ID='tempa' NAME='tempa' frameborder='0' width='0' height='0' style='width:0;Height:0;'>" & vbCrlf

  End Function

  '**************************************************

  '函数ID:0025[取得数据库链接字串]

  '函数名:GetConnStr

  '作 用:取得数据库链接字串,能生成MsAccess和MsSqlServer链接串

  '参 数:Lx ---- 0 是MsAccess , 1 是MsSqlServer

  '参 数:Dbiporpath ---- 数据库IP或路径

  '参 数:Dbmc ---- 数据库名称

  '参 数:Dbuid ---- 数据库用户名称

  '参 数:Dbupwd ---- 数据库用户密码

  '返回值:链接字串

  '示 例:http://www.knowsky.com/

  '**************************************************

  Public Function GetConnStr(ByVal Lx,ByVal Dbiporpath,ByVal Dbmc,ByVal Dbuid,ByVal Dbupwd)

  GetConnStr=""

  If Lx=0 Then

  If Right(Dbiporpath,1)<>"\" Then Dbiporpath=Dbiporpath & "\"

  GetConnStr ="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="&Dbiporpath&Dbmc&";Jet OLEDB:Database Password="&Dbupwd&";"

  End If

  If Lx=1 Then

  GetConnStr ="DRIVER=SQL Server;UID="&Dbuid&";DATABASE="&Dbmc&";SERVER="&Dbiporpath&";PWD="&Dbupwd&";"

  End If

  End Function

  '**************************************************

  '函数ID:0026[取得multipart/form-data形式上传文件]

  '函数名:GetImageData

  '作 用:取得multipart/form-data形式上传文件

  '参 数:MaxSize ---- 上传的限止大小,单位:M(兆)

  '返回值:二进制数据

  '示 例:

  '**************************************************

  Public Function GetImageData(ByVal MaxSize)

  GetImageData=""

  DIM formsize,Formdata,bncrlf,divider,datastart,dataend,mydata

  formsize=Request.TotalBytes

  if (formsize<=(MaxSize*1024*1024)) then

  Formdata=Request.BinaryRead(formsize)

  Pos_ts=LenB(getByteString(Chr(13) & Chr(10) & Chr(13) & Chr(10)))

  Pos_b=InstrB(Formdata,getByteString(Chr(13) & Chr(10) & Chr(13) & Chr(10)))+Pos_ts

  nFormdata=MidB(Formdata,Pos_b)

  Pos_ts=InstrB(nFormdata,getByteString(Chr(13) & Chr(10) & "--"))

  nnFormdata=MidB(nFormdata,Pos_ts)

  Pos_e=LenB(Formdata)-LenB(nnFormdata)-Pos_b+1

  datastart =Pos_b

  dataend=Pos_e

  mydata=midb(Formdata,datastart,dataend)

  End If

  GetImageData=mydata

  End Function

  '''' 将字串转为二进制串

  Function getByteString(StringStr)

  For i=1 to Len(StringStr)

  char=Mid(StringStr,i,1)

  getByteString=getByteString & chrB(AscB(char))

  Next

  End function

  '**************************************************

  '函数ID:0027[保存或查看上传到数据库中的数据,带调用上传窗口]

  '函数名:GoImgToDb

  '作 用:保存或查看上传到数据库中的数据,带调用上传窗口

  '参 数:PPLX ---- 执行类型(空为保存,ID号为查看该ID的文件)

  '参 数:PUrl ---- 主执行程序的URL部份

  '参 数:ConnStr ---- 上传文件的数据库链接字串

  '参 数:ImagTbname ---- 文件保存的数据表名称

  '参 数:Did ---- 文件ID字段名

  '参 数:Dmc ---- 文件名称字段名

  '参 数:Dlx ---- 文件类型字段名

  '参 数:Dmem ---- 文件说明字段名

  '参 数:Ddata ---- 文件的二进制数据的字段名

  '参 数:MaxSize ---- 上传的限止大小,单位:M(兆)

  '参 数:IDLX ---- 标识ID字段的类型 ( 0 字符型 1 数值(非自增量型) 2 数值型(自增量型) )

  '返回值:成功保存的JAVASCRIPT 注在非自动增量情况下标识字段长度应超过20个字符

  '示 例:GoImgToDb("17","http://127.0.0.1/function.asp",GetConnStr(1,"127.0.0.1","temp","sa","mzy1029"),"img","id","mc","lx","mem","data",20)

  '示 例:GoImgToDb("","http://127.0.0.1/function.asp",GetConnStr(1,"127.0.0.1","temp","sa","mzy1029"),"img","id","mc","lx","mem","data",20)

  '**************************************************

  Public Function GoImgToDb(ByVal PPLX,ByVal PUrl,ByVal ConnStr,ByVal ImagTbname,ByVal Did,ByVal Dmc,ByVal Dlx,ByVal Dmem,ByVal Ddata,ByVal MaxSize,ByVal IDLX)

  DIM Pjobs,Pjurl

  tempimg_conn_str=ConnStr

  Set fu_Conn=server.createobject("ADODB.Connection")

  Set fu_Rs=server.createobject("ADODB.Recordset")

  fu_Conn.open tempimg_conn_str

  If JCID(PPLX)=0 Then

  Pjobs=Request("img")

  If InStr(PUrl,"?")>0 Then

  Pjurl=PUrl&"&img=sav"

  Else

  Pjurl=PUrl&"?img=sav"

  End If

  If Pjobs="" then Response.write PosImageWin(Pjurl)

  If Pjobs="sav" Then

  Sql_Str="SELECT "&Did&","&Dmc&","&Dlx&","&Dmem&","&Ddata&" FROM "&ImagTbname

  fu_Rs.open Sql_Str,fu_Conn,3,3

  fu_Rs.addnew

  If IDLX < 2 Then

  fu_Rs(Did) =MakeTheID()

  End If

  fu_Rs(Dmc) =Request("mc")

  fu_Rs(Dlx) =Request("lx")

  fu_Rs(Dmem) =Request("mem")

  fu_Rs(Ddata).AppendChunk GetImageData(JCID(MaxSize))

  fu_Rs.update

  fu_Rs.Close

  fu_Rs.open Sql_Str,fu_Conn,3,3

  fu_Rs.MoveLast

  Response.write "<SCRIPT LANGUAGE=JAVASCRIPT>"&vbCrlf

  Response.write "parent.POMem.ImageID.value='"&fu_Rs(Did)&"';"&vbCrlf

  Response.write "parent.bc.innerHTML='已成功保存数据!';"

  Response.write "</SCRIPT>"&vbCrlf

  End If

  Else

  If IDLX > 0 Then

  Sql_Str="SELECT "&Did&","&Dmc&","&Dlx&","&Dmem&","&Ddata&" FROM "&ImagTbname&" WHERE ("&Did&" ="&PPLX&")"

  Else

  Sql_Str="SELECT "&Did&","&Dmc&","&Dlx&","&Dmem&","&Ddata&" FROM "&ImagTbname&" WHERE ("&Did&" ='"&PPLX&"')"

  End If

  fu_Rs.open Sql_Str,fu_Conn,1,1

  If fu_Rs.RecordCount >0 Then

  tempaa=Trim(fu_Rs(Dlx))

  Response.Clear

  Response.Expires = -9999

  Response.AddHeader "pragma", "no-cache"

  Response.AddHeader "cache-ctrol", "no-cache"

  Response.Buffer = TRUE

  Response.AddHeader "Content-Disposition:","attachment;filename="&fu_Rs(Dmc)&"."&tempaa

  Response.ContentType="application/"&Trim(fu_Rs(Dlx))

  Response.Flush

  Response.BinaryWrite fu_Rs(Ddata)

  Response.End

  End If

  End If

  fu_Rs.Close

  fu_Conn.close

  Set fu_Rs = Nothing

  Set fu_Conn = Nothing

  End Function

  '**************************************************''''

  '函数ID:0028[取得图像的类型|宽|高]

  '函数名:GetImageDx

  '作 用:取得图像的类型|宽|高

  '参 数:filepath ---- 文件路径及文件命名

  '返回值:"类型|宽|高"

  '**************************************************''''

  Public Function GetImageDx(ByVal filepath)

  DIM Tempsm,NBxx,WJXX(3)

  SET Tempsm = Server.CreateObject("ADODB.Stream")

  Tempsm.Mode=3

  Tempsm.Type=1

  Tempsm.Open

  Tempsm.LoadFromFile filepath

  NBxx=Hex(BinVal(Tempsm.Read(3)))

  WJXX(0)=NBxx

  WJXX(1)="0"

  WJXX(2)="0"

  If NBxx="464947" Then

  WJXX(0)="GIF"

  Tempsm.Read(3)

  WJXX(1)=BinVal(Tempsm.Read(2))

  WJXX(2)=BinVal(Tempsm.Read(2))

  End If

  If NBxx="FFD8FF" Then

  WJXX(0)="JPG"

  do

  do: p1=binVal(Tempsm.Read(1)): loop while p1=255 and not Tempsm.EOS

  if p1>191 and p1<196 then exit do else Tempsm.Read(binval2(Tempsm.Read(2))-2)

  do:p1=binVal(Tempsm.Read(1)):loop while p1<255 and not Tempsm.EOS

  loop while true

  Tempsm.Read(3)

  WJXX(2)=binval2(Tempsm.Read(2))

  WJXX(1)=binval2(Tempsm.Read(2))

  End If

  If Mid(NBxx,3)="4D42" Then

  Tempsm.Read(15)

  WJXX(0)="BMP"

  WJXX(1)=binval(Tempsm.Read(4))

  WJXX(2)=binval(Tempsm.Read(4))

  End If

  If NBxx="4E5089" Then

  WJXX(0)="PNG"

  Tempsm.Read(15)

  WJXX(1)=BinVal2(Tempsm.Read(2))

  Tempsm.Read(2)

  WJXX(2)=BinVal2(Tempsm.Read(2))

  End If

  If NBxx="535743" Then

  WJXX(0)="SWF"

  Tempsm.Read(5)

  binData=Tempsm.Read(1)

  sConv=Num2Str(ascb(binData),2 ,8)

  nBits=Str2Num(left(sConv,5),2)

  sConv=mid(sConv,6)

  while(len(sConv)<nBits*4)

  binData=Tempsm.Read(1)

  sConv=sConv&Num2Str(ascb(binData),2 ,8)

  wend

  WJXX(1)=int(abs(Str2Num(mid(sConv,1*nBits+1,nBits),2)-Str2Num(mid(sConv,0*nBits+1,nBits),2))/20)

  WJXX(2)=int(abs(Str2Num(mid(sConv,3*nBits+1,nBits),2)-Str2Num(mid(sConv,2*nBits+1,nBits),2))/20)

  End If

  Tempsm.Close

  SET Tempsm=nothing

  GetImageDx = WJXX(0)&"|"&WJXX(1)&"|"&WJXX(2)

  End Function

  Function BinVal(bin)

  dim ret

  ret = 0

  for i = lenb(bin) to 1 step -1

  ret = ret *256 + ascb(midb(bin,i,1))

  next

  BinVal=ret

  End Function

  Function BinVal2(bin)

  dim ret

  ret = 0

  for i = 1 to lenb(bin)

  ret = ret *256 + ascb(midb(bin,i,1))

  next

  BinVal2=ret

  End Function

  Function Str2Num(str,base)

  dim ret

  ret = 0

  for i=1 to len(str)

  ret = ret *base + cint(mid(str,i,1))

  next

  Str2Num=ret

  End Function

  Function Num2Str(num,base,lens)

  dim ret

  ret = ""

  while(num>=base)

  ret = (num mod base) & ret

  num = (num - num mod base)/base

  wend

  Num2Str = right(string(lens,"0") & num & ret,lens)

  End Function

  (3)将资料中的单引号改成两个单引号,并且在前后加上单引号

  Function SqlStr( data )

  SqlStr = "'" & Replace( data,"'", "''" ) & "'"

  End Function

  '写入数据库

  sql = "Insert Into 内容表 (看板id,主题id,作者id,标题,内容)Values( "

  sql = sql & SqlStr(topicid) & ","

  sql = sql & SqlStr(boardid) & ","

  sql = sql & SqlStr(author) & ","

  sql = sql & SqlStr(title) & ","

  sql = sql & SqlStr(content) & ")"

  conn.Execute sql

  %>

  < h2>文章已经被发送到数据库,当板主审阅后就可以看到了<h2>

  < /body>

  < /html>

  到这儿,文章已经被保存在数据库中了。但是,它并不能够立刻被显示出来,还需要版主的认可才行。下面,就来看看论坛的管理部分的内容。

  4、论坛的管理部分

  这儿是我们这个论坛的核心之所在,但它实现起来也没有什么特别的地方。还是那些老东西:窗体处理,数据库查询,在用ASP把他们有机的结合起来。当进入了文章审阅模式(前面提到的板务处理)之后,最为首要的内容,应该是对版主的身份进行验证了。下面来看看版主登陆页面:

  < %

  boardid=request("boardid")

  (注:boardid是由进入这个页面的连接所传递过来的,是要进行板务处理的看板的ID。通过它才能知道处理的是那个板的板务。)

  Set conn = erver.CreateObject("ADODB.Connection")

  conn.Open "driver={Microsoft AccessDriver (*.mdb)};dbq=" & Server.MapPath("bbssystem.mdb")

  Set cmd = Server.CreateObject("ADODB.Command")

  Set cmd.ActiveConnection = conn

  cmd.CommandText = "板主密码查询"

  ReDim param(0)

  param(0) = CLng(boardid) //注:CLng 不可忽略

  Set rs = cmd.Execute( ,param )

  boardmanager=rs("板主")

  set cmd=nothing

  %>

  < html>

  < head>

  < title>Untitled Document< /title>

  < meta http-equiv="Content-Type"content="text/html; charset=GB2312">

  < /head>

  < body bgcolor="#FFFFFF">

  < p>只有板主< %=boardmanager%>才能够进入这个地方</p>

  < p>请输入验证密码, 并且为了保持身份验证,请打开浏览器的Cookies。</p>

  < form method="post" action="managerloginrest.asp">

  < input type="password" name="password">

  < input type="hidden" name="boardid"value=< %=boardid%>>

  < input type="submit" name="Submit"value="确定">

  < /form>

  注:这个页面仅仅是用来登陆用的,它得到斑竹输入的密码后,并不能进行验证,而是将验证的工作放到下一个页面中进行。实际上,密码输入和验证的工作是可以放在一个页面中完成的,只不过程序代码的结构安排上有点麻烦。

  < /body>

  < /html>

  < %

  set rs=nothing

  conn.close

  set conn=nothing

  %>

  现在得到了版主ID和输入的密码,下面就是进行验证的工作managerloginrest.asp了,它接受上面那个文件中窗体的内容,并进行相关处理:

  < %

  response.buffer=true

  注:把缓冲区设置为允许使用。这一条一般来说,是应该加在每个ASP页面的首部的,这样能够提高ASP页面的性能。在打开了缓冲区后,ASP中还有一些相应的特殊用法,在后面会提及。

  boardid=request("boardid")

  password=request("password")

  Set conn = Server.CreateObject("ADODB.Connection")

  conn.Open "driver={Microsoft AccessDriver (*.mdb)};dbq=" & Server.MapPath("bbssystem.mdb")

  Set cmd = Server.CreateObject("ADODB.Command")

  Set cmd.ActiveConnection = conn

  cmd.CommandText = "板主密码查询"

  ReDim param(0) ' 声明

  param(0) = CLng(boardid)//注:CLng不可忽略

  Set rs = cmd.Execute( ,param )

  boardmanager=rs("板主")

  if password< > rs("密码")then %>

  < html>

  < head>

  < title>身份验证< /title>

  < meta http-equiv="Content-Type"content="text/html; charset=GB2312">

  < /head>

  < body bgcolor="#FFFFFF">

  密码错误

  < /body>

  < /html>

  < %

  else

  session("beenthere")=boarded

  注:使用Session来保持对版主的身份验证,这必须要求客户端浏览器的cookie被打开了。因为Session是通过cookie来实现的。在这儿,把看板ID赋给Session变量beenthere,表明版主主已经通过了身份验证。在后面的每个版务处理的页面中,都要检查beenthere是否和相应的看版ID相符。

  url="boardmanager.asp?boardid="& boardid

  response.redirect url

  补充:初学ASP的时候总是为response.redirect这个方法感到困惑,屡用不爽,现在我来告诉你一些技巧。使用它之前,必须通过response.buffer=true来让ASP页面使用缓冲区。这时,在ASP被解释成HTML程序代码之前,它是放在缓冲区中的,而不直接被发送的客户端浏览器。还有一个必须要知道的是:在使用response.redirect之前,是不能有任何实际的HTML程序代码被发送到客户端浏览器的,否则就会出错。当然也有变通的方法,如果在response.redirect之前已经有HTML程序代码被解释出来,可以用response.clear方法来清除缓冲区,然后就可以使用它来进行复位向了。

  end if

  %>

  注:下面就是在上面身份验证通过后复位向的目标:boardmanager.asp。它将列出了所有别有被处理的文章。

  < %

  boardid=request("boardid")

  if session("beenthere")< >boardidthen response.redirect "forums.asp"

  注:这就是检验版主身份的地方,因为前面已经通过cookie在斑竹的浏览器中作了标记,现在我们就能够通过seesion来辨认版主的身份了。如果标示不符,就会通过response.redirect返回到最开始的登陆页面。如果版主浏览器的cookie没有打开,那么seesion("beenthere")的值会为空,同样也无法进入这个页面。

  Set conn = Server.CreateObject("ADODB.Connection")

  conn.Open "driver={Microsoft AccessDriver (*.mdb)};dbq=" & Server.MapPath("bbssystem.mdb")

  Set cmd = Server.CreateObject("ADODB.Command")

  Set cmd.ActiveConnection = conn

  sql="select 名称 from 看板列表 whereid=" & boardid

  set rs=conn.execute(sql)

  boardname=rs("名称")

  cmd.commandtext="未发表文章列表"

  ReDim param(0)

  param(0) = CLng(boardid)//注:Clng 不可忽略

  Set rs = cmd.Execute( ,param )

  set cmd=nothing

  %>

  < html>

  < head>

  < title>版务处理< /title>

  < meta http-equiv="Content-Type"content="text/html; charset=GB2312">

  < /head>

  < body bgcolor="#FFFFFF">

  < h1 align="center"><%=boardname%>版务管理< /h1>

  < hr>

  < %

  if rs.eof or rs.bof then response.write "<H2>现在没有文章要处理< /h2>"

  response.end

  %>

  注:如果没有新文章被网友发布,这给出相应的提示,并用response.end来结束此页的显示。

  < table width="90%" border="0"cellspacing="0" cellpadding="0"align="center" >

  < tr bgcolor="#FFFFCC">

  < td width="40%" height="20">主题</td>

  < td width="40%" height="20">文章标题</td>

  < td width="8%" height="20">作者</td>

  < td width="12%" height="20">日期</td>

  < /tr>

  < %

  do

  topicid=rs("主题id")

  articleid=rs("文章id")

  data=rs("日期")

  datastr=cstr(year(data)) & "-"& cstr(month(data)) &"-"& cstr(day(data))

  author=rs("作者")

  articlename=rs("标题")

  topicname=rs("主题")

  response.write "< tr>< td><a href=qtopic.asp?topicid="& topicid& ">" & topicname &"< /A>< /td>"

  response.write "< td>< a href=managearticle.asp?articleid="&articleid & "&boardid="& boardid &">" &articlename & "< /A>< /td>"

  response.write "< td>< a href=qauthor.asp?author="&author & ">" & author& "< /a>< /td>"

  response.write "< td>" &datastr & "< /td>< /tr>"

  rs.movenext

  loop until rs.eof

  %>

  < /table>

  < /html>

  < %

  set rs=nothing

  conn.close

  set conn=nothing

  %>

  < /body>

  当点击了相应文章的联结后,就进入此文章的处理页面managearticle.asp:

  < %

  articleid=request("articleid")

  boardid=request("boardid")

  if session("beenthere")< >boardidthen response.redirect "forums.asp"

  Set conn = Server.CreateObject("ADODB.Connection")

  conn.Open "driver={Microsoft AccessDriver (*.mdb)};dbq=" & Server.MapPath("bbssystem.mdb")

  Set cmd = Server.CreateObject("ADODB.Command")

  Set cmd.ActiveConnection = conn

  cmd.CommandText = "按id查询文章"

  ReDim param(0)

  param(0) = CLng(articleid)//注:Clng 不可忽略

  Set rs = cmd.Execute( ,param )

  author=rs("作者id")

  title=rs("标题")

  data=rs("日期")

  rate=rs("推荐度")

  boardid=rs("看板id")

  topicid=rs("主题id")

  boardname=rs("看板名")

  topicname=rs("主题名")

  content=rs("内容")

  content=replace(content,vbCrlf,"</p>< p>")

  content="< p>" & content& "< /p>"

  set cmd=nothing

  %>

  < html>

  < head>

  < title>Untitled Document< /title>

  < meta http-equiv="Content-Type"content="text/html; charset=GB2312">

  < /head>

  < body bgcolor="#E9E9E4">

  < table width="89%" border="0"cellspacing="0" cellpadding="0"align="center">

  < tr bgcolor="#CCCCCC">

  < td>作者:< font color="#FF3366"><a href="qauthor.asp?author=< %=author%>">< %=author%> < /a>< /font>发表日期:< font color="#FF3333"><%=data%>< /font>

  看板:< font color="#FF3333"><a href="qboard.asp?boardid=< %=boardid%>">< %=boardname%>< /a>< /font>板主推荐:< font color="#FF3333">#rate#</font>< /td>

  < /tr>

  < tr bgcolor="#CCCCCC">

  < td>标题:< font color="#FF3333"><%=title%>

  主题:< a href="qtopic.asp?topicid=<%=topicid%>"> < %=topicname%>< /a> < /font>< /td>

  < /tr>

  < tr valign="top">

  < td>

  < hr>

  < font color="#FF3366">文章内容:< /font>< br>

  < br>

  < font color=blue>< %response.writecontent%>< /font>

  < br>

  < hr>

  < /td>

  < /tr>

  < tr valign="top">

  < form method="post" action="manageresult.asp">

  < td height="18">

  < table width="100%" border="1"cellspacing="1" cellpadding="1">

  < tr>

  < td width="29%">

  < div align="right">

  < input type="hidden" name="boardid"value="< %=boardid%>">

  < input type="hidden" name="topicid"value="< %=topicid%>">

  < input type="hidden" name="articleid"value="< %=articleid%>">

  文章处理:< /div>

  < /td>

  < td width="12%" bordercolor="#006666">删除:

  < input type="radio" name="manage"value=1>

  < /td>

  < td width="30%" bordercolor="#006666">发表:

  < input type="radio" name="manage"value=2>

  推荐等级

  < select name="select">

  < option value="1">1</option>

  < option value="2">2</option>

  < option value="3" selected>3</option>

  < option value="4">4</option>

  < option value="5">5</option>

  < /select>

  < /td>

  < td width="20%" bordercolor="#006666">以后再处理:

  < input type="radio" name="manage"value=3>

  < /td>

  < td width="9%">

  < input type="submit" name="Submit"value="确定">

  < /td>

  < /tr>

  < /table>

  < /td>

  < /form>

  < /tr>

  < /table>

  < /body>

  < /html>

  < %

  set rs=nothing

  conn.close

  set conn=nothing

  %>

  注:这一页和文章显示模块中的article.asp基本上是一样的,仅仅是多加入了版主处理的窗体,在这儿就不多讲了。

  下面,要根据版主的处理过程,修该数据库相应部分

  < %response.buffer=true%>

  < html>

  < head>

  < title>文章处理< /title>

  < meta http-equiv="Content-Type"content="text/html; charset=GB2312">

  < /head>

  < body bgcolor="#E9E9E4">

  < %

  articleid=request("articleid")

  boardid=request("boardid")

  topicid=request("topicid")

  manage=request("manage")

  '接受窗体内容

  response.write manage '显示斑竹ID

  if session("beenthere")< >boardidthen response.redirect "forums.asp"

  Set conn = Server.CreateObject("ADODB.Connection")

  conn.Open "driver={Microsoft AccessDriver (*.mdb)};dbq=" & Server.MapPath("bbssystem.mdb")

  根据上页中版主的操作,下面进行相应的处理。

  if CLng(request("manage"))=1 then

  sql="delete from 内容表 where id="& articleid

  conn.execute sql

  response.write "< h1>文章已经被删除</h1>"

  response.write "< a href=>back</a>"

  elseif CLng(request("manage"))=2then

  sql="update 内容表 set 发表=true whereid=" & articleid

  conn.execute sql

  sql="update 主题表 set 文章数=文章数+1where id=" & topicid

  conn.execute sql

  response.write "< h1>文章已经发表</h1>"

  response.write "< a href=>back</a>"

  else

  response.clear

  response.redirect "boardmanager.asp?boardid="& boarded

  end if

  %>

  < /body>

  < /html>

  < %

  conn.close

  set conn=nothing

  %>

  经过上面几步,所有的部分就算是基本完成了,当然,这时还不能拿来用,摆不上台面的。如果想要能够拿得出来的话,还要在版面设计,客户端资料验证等方面多下一些功夫。不过那都是HTML的内容了,和ASP没多大的关系,这儿我就不多讲了。