AutoCAD 3DMAX C语言 Pro/E UG JAVA编程 PHP编程 Maya动画 Matlab应用 Android
Photoshop Word Excel flash VB编程 VC编程 Coreldraw SolidWorks A Designer Unity3D
 首页 > VB编程

用VB编写Windows CGI应用程序

51自学网 http://www.wanshiok.com


---- 由 于 编 译 使 用 这 个CGI 程 序 的 做 法 与 上 面 完 全 相 同, 故 下 面 仅 给 源 程 序 代 码:

Option Explicit
Const BOOK_FILE = "guestbk.csv" '存放客户
数据的文件,自动生成,可用Excel97调阅
Declare Sub Sleep Lib "kernel32"
(ByVal dwMilliseconds As Long)
Sub CGI_Main()
If CGI_RequestMethod = "POST" Then
EnterGuest
Beep
Else
ReturnForm
End If
End Sub'

---- 一 当Web 客 户 要 求CGI 连 接, 服 务 器 执 行ReturnForm(), 送 出 征 求 建 议 的 表 单:
Sub ReturnForm()
Send "Content-type: text/html"
Send ""
Send ("< HTML >< HEAD >< TITLE >贵州大学
< /TITLE >< /HEAD >")
Send ("< BODY >< H2 >欢迎您访问贵州
大学计算机软件与理论研究所WWW站点< /H1 >")
Send ("我们的e-mail是< A HREF=""mailto:"
& CGI_ServerAdmin & _
""" >lixiang@gzu.edu.cn:< /A >")
Send ("< HR >")
Send ("请填下表,留下您的宝贵建议:")
Send ("< FORM ACTION="""
& CGI_ExecutablePath & """ METHOD=""POST"" >")
Send ("< PRE > 您的姓名:
< INPUT SIZE=25 NAME=""name"" >")
Send (" E-mail地址:
< INPUT SIZE=25 NAME=""email"" >")
Send ("您给我们的建议:< TEXTAREA COLS=40
ROWS=4 WRAP=VIRTUAL NAME=""comments"" >")
Send ("< /TEXTAREA >< /PRE >")
Send ("请击此处将您的建议送我们:
< INPUT TYPE=""submit""")
Send ("VALUE=""发送您的建议"" >")
Send ("< HR >")
Send ("< /FORM >< /BODY >< /HTML >")
End Sub

'获取客户建议表单数据,将所填数据存入文件guestbk.csv并向客户返回一个信息
Sub EnterGuest()
Dim iLockTries As Integer
Dim sDate As String
Dim sName As String
Dim sEmail As String
Dim sComments As String
'Dim sBrowser As String
Dim sFirstName As String
Dim fn As Integer
'提取建议的有关数据:
sName = GetSmallField("name")
sEmail = GetSmallField("email")
sComments = GetSmallField("comments")
iLockTries = 0
fn = FreeFile
On Error GoTo gLockFail
gRetryLock:
Open App.Path + "/" + BOOK_FILE For
Append Lock Read Write As #fn
On Error GoTo 0
sDate = Now
Write #fn, sDate, sName, sEmail,
sComments, CGI_RemoteAddr
Close #fn
sFirstName = Trim$(Left$(sName,
InStr(sName, " ")))
If sFirstName < > ""
Then sFirstName = sFirstName & ", "
Send ("Content-type: text/html")
Send ("")
Send ("< HTML >< HEAD >< TITLE >谢谢您!
< /TITLE >< /HEAD >")
Send ("您的签名与建议是:< PRE >")
Send ("日期: " & sDate)
Send ("姓名: " & sName)
Send ("E-Mail: " & sEmail)
Send ("Host address:
[" & CGI_RemoteAddr & "]")
Send ("建议:< /PRE >")
Send (sComments)
Send ("< H2 >谢谢您!< /H2 >")
Send ("< /BODY >< /HTML >")
Exit Sub
gLockFail:
Sleep (1000)
iLockTries = iLockTries + 1
Resume gRetryLock
End Sub

Sub Inter_Main()
MsgBox "这是CGI程序,
需要在Web服务器中运行。", 16, "CGI.BAS"
End Sub

 
 

上一篇:Modem通讯意外处理  下一篇:用VB做的合路器