亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

asp簡單的ajax留言板(采用三層模式)

2019-11-18 17:12:07
字體:
來源:轉載
供稿:網友

好久沒有寫過asp了,這回寫個留言板還真覺得有點難度,競然寫了整整一天,哈哈.
就只有留言其它的都什么也沒寫,采用三層結構(不知道算不算,本來對三層的概念很糊涂)

演示www.zj55.com的留言板,希望各位大哥大姐如果發現有漏洞的話請在這里告訴我,千萬不要黑我的網站,在這里小弟先謝過了.

index.asp
<%@ codepage=65001%>
<%
option explicit
%>
<% Response.Charset="utf-8"%>
<% session.CodePage=65001 %>
<!-- #include file="AccHelper.asp" -->
<!-- #include file="Common.asp"-->
<!-- #include file="DAL_Guest.asp" -->
<!-- #include file="MOD_Guest.asp" -->
<!-- #include file="BLL_Guest.asp" -->
<%
 Dim mybll
 Dim myList
 Set mybll = new BLL_Guest
 Select Case Request("tCMD")
  Case "SAVE"
   mybll.Insert()
  Case "DEL"
   mybll.Delete()
 End Select
 myList = mybll.FindByPage()
%>
<h2>客戶留言</h2>
<p>
<form name="subForm" id="subForm">
 <textarea id="con" name="con" cols="56" rows="6" wrap="VIRTUAL"></textarea>
 <input type="button" name="submit" value="提交留言" onclick="$('guest/index.asp?tCMD=SAVE&content='+escape(this.form.con.value))" />
</form>
</p>
<%=myList%>

BLL_Guest.asp
<%
 '/// <summary>
 '/// 摘要說明。
 '/// </summary>
 Class BLL_Guest

  PRivate mycom,mymod,mydal

  Private LI,UL

  Private DEL
 
  '獲取信息
  Public Sub GetGuest()

   mydal.GetGuest(Id)

  End Sub

  '新增信息
  Public Sub Insert()
  
   mymod.Content = Request("content")
   mymod.re = Request("Re")
   mymod.Addtime = Now()
   mymod.ip = request.servervariables("HTTP_X_FORWARDED_FOR")
   If len(mymod.Ip)<=0 Then mymod.Ip = request.servervariables("REMOTE_ADDR")

   Call mydal.Insert(mymod)

  End Sub

  '更新信息
  Public Sub Update()

   Call mydal.Update(mymod)

  End Sub

  '刪除信息
  Public Sub Delete()

   mydal.Delete(Request("Id"))

  End Sub

  '查找信息
  Public Function FindByPage()

   Dim PageSize,CurrentPage,WhereValue,OrderValue,RecordCount
   Dim objRS
   Dim tmp1,tmp2,tmp3,parms,i
   Dim tCMD
   tCMD = Request("tCMD")
   PageSize = "8"
   CurrentPage = Request("PageNo")
   If Len(CurrentPage)<=0 Then
    CurrentPage=1
   End If
   WhereValue = ""
   OrderValue = "Id"
   Set objRS = mydal.FindByPage(PageSize,CurrentPage-1,WhereValue,OrderValue)
   i = 1
   RecordCount = mydal.Count(WhereValue)
   Do While Not objRS.EOF
    If tCMD="DEL" Then
     DEL = "<a href=""?tCMD=DEL&Id="&objRS("Id")&""">刪除</a>"
    Else
     DEL = ""
    End If
    parms=Array(i,objRS("content"),objRS("ip"),objRS("addtime"),DEL)
    tmp1 = tmp1 & mycom.Format(LI,parms)
    objRs.Movenext
    i = i + 1
   Loop
   tmp3 = mycom.Page(PageSize,CurrentPage,RecordCount,"guest/index.asp?tCMD=LIST")
   parms=Array(tmp1,tmp3)
   tmp2 = tmp2 & mycom.Format(UL,parms)

   FindByPage = tmp2

  End Function

  Private Sub Class_Initialize()

   LI = "<li><span>{0}</span> <span>{1}</span><br /><span>作者:{2}</span> <span>{3}</span> <span>{4}</span></li>" & vbCrLf
   UL = "<UL>{0}<li>{1}</li></UL>"
   DEL = ""

   Set mycom = new Common
   set mymod = new MOD_Guest
   set mydal = new DAL_Guest

  End Sub

  Private Sub Class_Terminate()

   Set mycom = Nothing
   Set mymod = Nothing
   set mydal = Nothing

  End Sub

 End Class
%>

DAL_Guest.asp
<%
 '/// <summary>
 '/// 摘要說明。
 '/// </summary>
 Class DAL_Guest
 
  Private SQL_01
  Private SQL_02
  Private SQL_03
  Private SQL_04
  Private SQL_05
  Private SQL_06
  Private SQL_07

  Private mycom,myacc,mymod

  '/// <summary>
  '/// 獲得信息
  '/// </summary>
  '/// <param name="Id">判斷字段</param>
  '/// <returns>信息體</returns>
  Public Function GetGuest(Id)

   Dim parms,SQL,objRS
   parms = Array(Id)
   SQL  = mycom.Format(SQL_01,parms)
   Set objRS = myacc.ExecuteReader(myacc.CONN_STRING,SQL)
   If  Not objRS.EOF then
    Call mymod.SetVar(objRs("Id"),objRs("Content"),objRs("Re"),objRs("Addtime"),objRs("Ip"))
    Set GetGuest = mymod
   Else
    GetGuest = Null
   End If
  
  End Function

  '/// <summary>
  '/// 插入信息
  '/// </summary>
  '/// <param name="">信息體</param>
  Public Sub Insert(vmod)

   Dim parms,SQL
   parms = Array(vmod.Content,vmod.Re,vmod.Addtime,vmod.Ip)
   SQL  = mycom.Format(SQL_02,parms)
   Call myacc.ExecuteReader(myacc.CONN_STRING,SQL)

  End Sub

  '/// <summary>
  '/// 更新信息
  '/// </summary>
  '/// <param name="">信息體</param>
  Public Sub Update(vmod)
  
   Dim parms,SQL
   parms = Array(vmod.Id,vmod.Content,vmod.Re,vmod.Addtime,vmod.Ip)
   SQL  = mycom.Format(SQL_03,parms)
   Call myacc.ExecuteReader(myacc.CONN_STRING,SQL)

  End Sub

  '/// <summary>
  '/// 刪除信息
  '/// </summary>
  '/// <param name="">信息體</param>
  Public Sub Delete(Id)

   Dim parms,SQL
   parms = Array(Id)
   SQL  = mycom.Format(SQL_04,parms)
   Call myacc.ExecuteNonQuery(myacc.CONN_STRING,SQL)

  End Sub

  '/// <summary>
  '/// 統計信息
  '/// </summary>
  '/// <param name="">信息體</param>
  Public Function Count(WhereValue)

   Dim parms,SQL,objRS
   parms = Array(WhereValue)
   SQL  = mycom.Format(SQL_07,parms)
   Set objRS = myacc.Recordset(myacc.CONN_STRING,SQL)
   Count = objRS.RecordCount

  End Function

  '/// <summary>
  '/// 根據條件列出所有信息(帶有分頁)
  '/// </summary>
  '/// <param name="PageSize">每頁記錄數</param>
  '/// <param name="CurrentPage">頁碼</param>
  '/// <param name="WhereValue">判斷值</param>
  '/// <param name="OrderValue">排序</param>
  '/// <returns>返回objRS</returns>
  Public Function FindByPage(PageSize,CurrentPage,WhereValue,OrderValue)

   Dim parms,SQL,objRS
   Dim s1
   If CurrentPage="0" Then  
    s1 =  PageSize & "|" + OrderValue & "|" & WhereValue
    parms = Split(s1,"|")
    SQL = mycom.Format(SQL_05,parms)
   Else
    s1 = PageSize & "|" & OrderValue & "|" + WhereValue & "|" & CurrentPage*PageSize
    parms = Split(s1,"|")
    SQL = mycom.Format(SQL_06,parms)
   End If

   Set objRS = myacc.ExecuteReader(myacc.CONN_STRING,SQL)
   Set FindByPage = objRS
  
  End Function


  Private Sub Class_Initialize()

   SQL_01 = "Select * From [Guest] Where Id = {0}"
   SQL_02 = "Insert into [Guest] ([Content],[Re],[Addtime],[Ip]) values('{0}','{1}','{2}','{3}')"
   SQL_03 = "Update [Guest] Set [Content]='{1}',[Re]='{2}',[Addtime]='{3}',[Ip]='{4}' Where Id = {0}"
   SQL_04 = "Delete From [Guest] Where Id In ({0})"
   SQL_05 = "Select Top {0} * From [Guest] Where Content Like '%{2}%' Order By {1} Desc,Id Desc"
   SQL_06 = "Select Top {0} * From [Guest] Where Content Like '%{2}%' And Id Not IN(Select Top {3} Id From [Guest] Where Content Like '%{2}%' Order By {1} Desc,Id Desc) Order By {1} Desc,Id Desc"
   SQL_07 = "Select * From [Guest] Where Content Like '%{0}%' "

   Set mycom = new Common
   Set myacc = new AccHelper
   Set mymod = new MOD_Guest

  End Sub

  Private Sub Class_Terminate()

   Set mycom = Nothing
   Set myacc = Nothing
   Set mymod = Nothing

  End Sub

 End Class
%>

MOD_Guest.asp
<%
 '/// <summary>
 '/// 摘要說明。
 '/// </summary>
 Class MOD_Guest

  Public Id
  Public Content
  Public Re
  Public Addtime
  Public Ip

  Public Sub SetVar(vId,vContent,vRe,vAddtime,vIp)
   Id=vId
   Content=vContent
   Re=vContent
   Addtime=vAddtime
   Ip=vIp
  End Sub

 End Class
%>

Common.asp
<%
 '/// <summary>
 '/// 摘要說明
 '/// </summary>
 Class Common

  '/// <summary>
  '/// 獲得信息
  '/// </summary>
  '/// <param name="Id">需要內容</param>
  '/// <param name="Id">替換關鍵字</param>
  '/// <returns>格式化后內容</returns>
  Public Function Format(str,arr)

   Dim r,i
   r = str  
   For i = 0 To UBound(arr)
    r = Replace(r,"{"&i&"}",arr(i))
   Next
   Format = r

  End Function

  Public Function Page(PageSize,CurrentPage,RecordCount,PageUrl)
  
   const C_RECORDCOUNT = "合計<STRONG><FONT color=""red"">{0}</FONT></STRONG>篇&nbsp;|"
   const C_FIRSTPAGE1 = "&nbsp;<a href=""#"" onclick=""$('{0}&amp;PageNo={1}')"">首頁</a>"
   const C_FIRSTPAGE2 = "&nbsp;首頁"
   const C_PREVPAGE1 = "&nbsp;<a href=""#"" onclick=""$('{0}&amp;PageNo={1}')"">上一頁</a>"
   const C_PREVPAGE2 = "&nbsp;上一頁"
   const C_NEXTPAGE1 = "&nbsp;<a href=""#"" onclick=""$('{0}&amp;PageNo={1}')"">下一頁</a>"
   const C_NEXTPAGE2 = "&nbsp;下一頁"
   const C_LASTPAGE1 = "&nbsp;<a href=""#"" onclick=""$('{0}&amp;PageNo={1}')"">尾頁</a>"
   const C_LASTPAGE2 = "&nbsp;尾頁"
   const C_CURRENTPAGE = "&nbsp;頁次:<STRONG><FONT color=""red"">{0}</FONT>/{1}</STRONG>頁"
   const C_PAGESIZE = "&nbsp;<STRONG>{0}</STRONG>篇/頁&nbsp;&nbsp;"
   const C_GOTOPAGE = "&nbsp;跳轉:<input type=""text"" name=""goto"" value=""{1}"" onchange=""$('{0}&amp;PageNo='+this.value)"" style=""width:20px;border:1px""/>&nbsp;&nbsp;"
  
   Dim PageCount,pages
   Dim lRecordCount,lFirstpage,lPrevpage,lNextpage,lLastpage,lCurrentpage,lPagesize,lGotopage
   Dim p,parms

   If RecordCount Mod PageSize <> 0 Then
    pages = 1
   else
    pages = 0
   End If
   PageCount=CInt(RecordCount/PageSize + pages)
  
   parms=Array(RecordCount)
   lRecordCount = Format(C_RECORDCOUNT,parms)

   if CInt(CurrentPage)>1 Then
    parms=Array(Pageurl,1)
    lFirstpage = Format(C_FIRSTPAGE1,parms)
    parms=Array(Pageurl,CInt(CurrentPage)-1)
    lPrevpage = Format(C_PREVPAGE1,parms)
   Else
    lFirstpage=C_FIRSTPAGE2
    lPrevpage=C_PREVPAGE2
   End If

   if CInt(CurrentPage)<PageCount Then
    parms=Array(Pageurl,CInt(CurrentPage)+1)
    lNextpage = Format(C_NEXTPAGE1,parms)
    parms=Array(Pageurl,CInt(CurrentPage)+1)
    lLastpage = Format(C_LASTPAGE1,parms)
   Else  
    lNextpage=C_NEXTPAGE2
    lLastpage=C_LASTPAGE2
   End If

   parms=Array(CurrentPage,PageCount)
   lCurrentpage = Format(C_CURRENTPAGE,parms)
   parms=Array(PageSize)
   lPagesize = Format(C_PAGESIZE,parms)
   parms=Array(Pageurl,CurrentPage)
   lGotopage = Format(C_GOTOPAGE,parms)
  
   p=lRecordCount&lFirstpage&lPrevpage&lNextpage&lLastpage&lCurrentpage&lPagesize&lGotopage
   Page = p

  End Function

 End Class
%>

AccHelper.asp
<%
 '/// <summary>
 '/// AccHelper 的摘要說明。
 '/// </summary>
 Class AccHelper

  Public CONN_STRING

  '/// <summary>
  '/// 執行ExecuteNonQuery
  '/// </summary>
  '/// <param name="connString">連接字符</param>
  '/// <param name="cmdText">sql命令</param>
  Public Function ExecuteNonQuery(connString,cmdText)
  
   Dim objConn
   Set objConn = Server.CreateObject("ADODB.Connection")
   objConn.Open connString
   objConn.Execute(cmdText)

  End Function

  '/// <summary>
  '/// 執行ExecuteReader
  '/// </summary>
  '/// <param name="connString">連接字符</param>
  '/// <param name="cmdText">sql命令</param>
  '/// <returns>RS</returns>
  Public Function ExecuteReader(connString,cmdText)
 
   Dim objConn,objRS
   Set objConn = Server.CreateObject("ADODB.Connection")
   objConn.Open connString
   Set objRS = objConn.Execute(cmdText)
   Set ExecuteReader = objRS

  End Function

  '/// <summary>
  '/// 執行Recordset
  '/// </summary>
  '/// <param name="connString">連接字符</param>
  '/// <param name="cmdText">sql命令</param>
  '/// <returns>RS</returns>
  Public Function Recordset(connString,cmdText)
 
   Dim objConn,objRS
   Set objConn = Server.CreateObject("ADODB.Connection")
   objConn.Open connString
   Set objRS = Server.CreateObject("ADODB.RecordSet")
   objRS.Open cmdText,objConn,1,3
   Set Recordset = objRS

  End Function

  Private Sub Class_Initialize()
   CONN_STRING = "provider = microsoft.jet.oledb.4.0;data source=" & Server.Mappath("db.mdb")
  End Sub

 End Class
%>


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97婷婷涩涩精品一区| 日本精品va在线观看| 日韩av电影在线播放| 中文字幕精品视频| 在线午夜精品自拍| 亚洲人成在线一二| 最新69国产成人精品视频免费| 欧美日韩精品在线| 奇米影视亚洲狠狠色| 亚洲精品视频在线观看视频| 日韩免费在线免费观看| 久久久精品在线| 国产一区二区三区欧美| 日韩欧美中文免费| 亚洲乱码国产乱码精品精| 国产精品亚洲一区二区三区| 国产精品自产拍高潮在线观看| 北条麻妃在线一区二区| 精品国产乱码久久久久久天美| 国产精品久久久久久av| 中文字幕精品一区二区精品| 8050国产精品久久久久久| 国内精品一区二区三区| 久久久免费高清电视剧观看| yellow中文字幕久久| 91久久久久久久| 伊人久久综合97精品| 精品视频久久久久久久| 久久久亚洲欧洲日产国码aⅴ| 国产日韩在线播放| 欧美专区福利在线| 欧美精品videofree1080p| 色妞久久福利网| 日本久久久久亚洲中字幕| 亚洲free性xxxx护士hd| 日本韩国在线不卡| 国产精品入口夜色视频大尺度| 亚洲第一精品自拍| 成人免费淫片视频软件| 91精品国产91久久久久久久久| 中文日韩在线视频| 久久精品成人动漫| 91美女片黄在线观| 欧美电影免费观看电视剧大全| 97香蕉超级碰碰久久免费的优势| 中文字幕亚洲欧美在线| 中文字幕亚洲国产| 亚洲免费伊人电影在线观看av| 国产精品精品久久久久久| 亚洲精品国产福利| 色综合久久天天综线观看| 在线电影av不卡网址| 91手机视频在线观看| 亚洲高清一区二| 欧美电影免费观看大全| www.欧美精品| 国产有码在线一区二区视频| 亚洲肉体裸体xxxx137| 欧美xxxwww| 欧美精品www在线观看| 国产亚洲aⅴaaaaaa毛片| 欧美性猛交xxxx富婆弯腰| 少妇精69xxtheporn| 国内精品久久久久久影视8| 午夜精品一区二区三区视频免费看| 国产第一区电影| 尤物yw午夜国产精品视频明星| 色樱桃影院亚洲精品影院| 日韩精品在线视频美女| 欧洲永久精品大片ww免费漫画| 91在线免费网站| 亚洲国产欧美久久| 欧美性受xxxx黑人猛交| 欧美大肥婆大肥bbbbb| 国产精品男人爽免费视频1| 亚洲人免费视频| 国产欧美日韩亚洲精品| 亚洲自拍偷拍色图| 亚洲精品不卡在线| 国产精品嫩草视频| 亚洲色图50p| 欧美视频国产精品| 久久中文久久字幕| 亚洲欧美国产va在线影院| 久久综合久久八八| 欧美高清在线观看| 精品日本美女福利在线观看| 亚洲精品大尺度| 国产精品成人一区| 国产91露脸中文字幕在线| 国产一区二区三区免费视频| 亚洲国产成人精品一区二区| 精品久久久久久国产91| 视频在线观看一区二区| 68精品国产免费久久久久久婷婷| 亚洲精品福利免费在线观看| 亚洲影院在线看| 国产精品久久久一区| 69影院欧美专区视频| 亚洲自拍中文字幕| 久久成人亚洲精品| 亚洲自拍中文字幕| 中文字幕亚洲综合久久筱田步美| 亚洲va欧美va在线观看| 欧美日韩在线另类| 欧美精品一区三区| 精品视频偷偷看在线观看| 欧洲美女7788成人免费视频| 精品久久久久久中文字幕| 精品视频—区二区三区免费| 亚洲欧美成人在线| 国产成人精品久久久| 91超碰中文字幕久久精品| 国a精品视频大全| 国产精品久久999| 国产精品福利在线观看| 久久精品小视频| 91成人免费观看网站| 国内精品久久久久| 久热精品在线视频| 国产成人福利夜色影视| 国产欧美日韩高清| 狠狠色噜噜狠狠狠狠97| 久久免费国产精品1| 国产亚洲在线播放| 日韩在线观看精品| 欧美性色19p| 日韩精品在线免费观看| 久久久精品国产网站| 韩曰欧美视频免费观看| 98视频在线噜噜噜国产| 欧洲午夜精品久久久| 91网站在线免费观看| 精品夜色国产国偷在线| 欧美色视频日本高清在线观看| 久久久久久国产三级电影| 成人免费直播live| 午夜免费在线观看精品视频| 国产69精品99久久久久久宅男| 久久在线免费视频| 亚洲欧美日韩精品久久亚洲区| 日本午夜人人精品| 亚洲自拍av在线| 亚洲肉体裸体xxxx137| 日本高清视频精品| 欧美一级电影久久| 亚洲性夜色噜噜噜7777| 日韩av在线一区二区| 奇米成人av国产一区二区三区| 国产一级揄自揄精品视频| 日韩av片免费在线观看| 日韩精品一区二区三区第95| 亚洲国产另类 国产精品国产免费| 国产精品网站大全| 久久成年人免费电影| www.国产精品一二区| 91精品国产综合久久香蕉的用户体验| 国产精品嫩草影院一区二区| 97精品伊人久久久大香线蕉| 成人网址在线观看| 欧美大尺度激情区在线播放| 国产精品视频永久免费播放| 欧美电影免费观看高清完整| 国产欧美一区二区白浆黑人|