c_程序設計課程設計-- 在線留言_第1頁
已閱讀1頁,還剩12頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

1、<p>  《C#程序設計》課程設計</p><p>  題 目: 在線留言 </p><p>  專 業(yè): 計算機科學與技術 </p><p>  學 號: </p><p>  姓 名: </p>&

2、lt;p>  指導老師: </p><p>  完成日期: 2012-12-26 </p><p><b>  目 錄</b></p><p><b>  1 前言1</b></p><p><b>  2 需求分析1

3、</b></p><p><b>  2.1要求1</b></p><p><b>  2.2任務1</b></p><p><b>  2.3運行環(huán)境1</b></p><p><b>  2.4開發(fā)工具1</b></p>

4、<p>  3 概要設計與詳細設計1</p><p>  3.1系統(tǒng)流程圖1</p><p>  3.2查詢函數(shù)流程圖2</p><p><b>  4 編碼與實現(xiàn)2</b></p><p><b>  4.1分析2</b></p><p>  4.2

5、具體代碼實現(xiàn)3</p><p>  5 課程設計總結3</p><p><b>  參考文獻3</b></p><p><b>  致 謝3</b></p><p><b>  1 前言</b></p><p>  隨著計算機的普及,人們可以更

6、方便的借助計算機這一平臺實現(xiàn)各種生活需求,此次的設計,就是為了設計一個留言本,其中包括了用戶留言,回復,管理員對留言信息的管理等基本功能,其中管理員可以刪除用戶留言,或者對用戶的留言進行回復等,這些功能都能方便的為大家所使用。給人們創(chuàng)造一個愉快的交流平臺。</p><p><b>  2 需求分析</b></p><p><b>  2.1需求分析</

7、b></p><p>  開發(fā)一個在線留言系統(tǒng),首先需要確定留言的功能是什么,也就是用戶想要的留言所能做的工作。用戶使用留言是按照一定的流程來進行的:用戶注冊登錄進入留言,可以就某個話題展開討論,通過留言功能發(fā)布新的話題,通過回帖的功能回復已有的話題;管理員要管理留言,系統(tǒng)需要具有的功能有創(chuàng)建、刪除留言的版塊,管理注冊的用戶,管理留言,設置留言基本參數(shù)。這樣的流程就決定了留言所應具有的功能。</p&g

8、t;<p>  觀察留言所有功能需求,按不同實體分類,可以分為四類實體對象:版塊、留言、用戶和留言。這四類對象,可以設計為四個數(shù)據(jù)實體,如果使用數(shù)據(jù)庫存儲它們,即可以設計四個基本數(shù)據(jù)表的集合來存儲這些實體的基本信息;它們可以設計為四個基本表,映射四個實體的基本數(shù)據(jù)。這些基本對象只是留言系統(tǒng)中最為基本的要素,對于一個完整的留言還需要其它相關的表來記錄相關的信息,即實體之間的相互關系信息。</p><p&g

9、t;  留言一般存在兩種用戶,注冊用戶和管理員。用戶的權限是向下覆蓋的,即上級權限包含下級權限,在這個留言中,管理員的權限是上級權限。</p><p>  留言系統(tǒng)的用戶瀏覽信息功能,是用戶討論問題的平臺,發(fā)帖、瀏覽、回帖一直貫穿用戶的整個活動。同時,由于留言系統(tǒng)的留言管理是管理員在留言瀏覽時進行的,因此編輯、刪除等功能也安排在瀏覽信息時實現(xiàn),只是一般用戶沒有權限做這些動作。其它與管理員相關的功能,包括版塊管理、

10、用戶管理和留言設置的都是需要管理員在管理模塊進行操作。</p><p><b>  2.2任務</b></p><p>  下面就管理員所做的管理進行介紹: </p><p>  查看留言:任何用戶可以根據(jù)發(fā)言者留下的郵箱地址發(fā)郵件。</p><p>  刪除留言:如果用戶發(fā)表了不符合留言規(guī)則的留言,則需要管理員刪除這些

11、留言。</p><p>  管理版塊:留言版塊需要先創(chuàng)建,才能被使用,管理員還可以刪改版塊的相關信息。</p><p>  設置參數(shù):留言一般有一些初始化信息,比如留言名稱、每頁顯示留言數(shù)量等參數(shù)信息,管理員可以在后臺界面自行設置。</p><p><b>  模塊設計:</b></p><p>  (1)登錄功能模塊:

12、用戶個人注冊、登錄,管理員登錄;</p><p>  (2)瀏覽功能模塊:用戶瀏覽版塊、瀏覽主題帖列表、查看留言;</p><p>  (3)發(fā)帖回帖功能模塊:用戶發(fā)帖,管理員回帖;</p><p>  (4)留言管理功能模塊:管理員編輯、刪除;</p><p>  (5)留言設置功能模塊:管理員設置留言參數(shù);</p><

13、p>  (6)用戶管理模塊:管理員添加、刪除。</p><p>  用戶注冊、登陸以及修改個人的注冊信息組合成注冊登錄模塊;用戶瀏覽版塊、瀏覽主體帖列表、查看留言組合成瀏覽模塊;用戶發(fā)帖;管理員編輯留言、刪除留言。以上四個模塊組成用戶使用的基本功能模塊。擴展功能模塊都是與管理員相關的,設置留言參數(shù)單獨為留言設置模塊;創(chuàng)建、修改和刪除版塊為管理版塊模塊;刪除和回復為管理用戶模塊。</p><

14、;p>  從以上分析,可以得到留言的功能框架,即系統(tǒng)的各個部分已經(jīng)確定,對于留言系統(tǒng)來說,各個模塊之間用一條主線串聯(lián)起來,才能構建完整的系統(tǒng)。聯(lián)系各個模塊的主線是使用者的權限,用戶能使用留言的哪些功能是由用戶的權限決定的。留言權限相對應。同一類用戶使用的功能模塊,是以使用者為中心連接起來的。另外,操作同一類事物的功能模塊,也是有相互關系的。因此,瀏覽模塊與發(fā)帖回帖模塊、管理留言模塊關聯(lián),是由留言的系統(tǒng)流程決定的。而管理版塊模塊與瀏

15、覽模塊關聯(lián),是由留言與版塊的父子關系決定的,留言附于版塊,先有版塊,后有留言,留言必須發(fā)表在某個版塊中。還有管理用戶模塊與注冊登錄模塊關聯(lián),是由同一類對象(用戶)決定的,用戶注冊后獲得留言的身份,成為用戶,所有的用戶需要接受管理員的管理,用戶登錄證明自己的留言中身份。</p><p><b>  2.3運行環(huán)境</b></p><p>  (1)WINDOWS2000

16、/XP系統(tǒng)</p><p> ?。?)TurboC2.0編譯環(huán)境</p><p><b>  2.4開發(fā)工具</b></p><p><b>  C#語言</b></p><p>  3 概要設計與詳細設計</p><p><b>  3.1系統(tǒng)流程圖</b&

17、gt;</p><p>  留言功能流程如圖3.1.1所示。</p><p>  圖3.1.1 留言功能流程圖 </p><p>  留言的模塊體系圖如圖3.1.2所示。</p><p>  圖3.1.2 留言的模塊圖</p><p>  3.2查詢函數(shù)流程圖</p><p> 

18、 該系統(tǒng)的實體有:管理員信息實體、用戶信息實體、留言實體、版面信息實體。實體之間的E-R圖如圖3.2所示。</p><p>  圖3.2 實體間的關系E-R圖</p><p>  考慮到將來功能上的完整性,設計如下面所示的數(shù)據(jù)項和數(shù)據(jù)結構:</p><p>  用戶信息:包括數(shù)據(jù)項有用戶名、密碼、頭銜、頭像、用戶等。</p><p> 

19、 留言信息:包括數(shù)據(jù)項有所屬版面、父留言的編號、子留言的編號、用戶、主題、內(nèi)容、發(fā)表時間等。</p><p>  基于上面的內(nèi)容,設計了下列表,這些表之間相互關聯(lián),共同存儲著系統(tǒng)所需要的數(shù)據(jù)。在設計數(shù)據(jù)庫表的過程中,一般要遵循幾條原則:數(shù)據(jù)庫設計一個表最好只存儲一個實體或對象的相關信息,不同的實體最好存儲在不同的數(shù)據(jù)表中,如果實體還可以再劃分,實體的劃分原則是最好能夠比當前系統(tǒng)要開發(fā)的實體的復雜度??;數(shù)據(jù)表的信息

20、結構一定要合適,表的字段的數(shù)量一般不要過多;擴展信息和動態(tài)變化的信息一定要分開在不同的表里;多對多這樣的表關系盡量不出現(xiàn)等。</p><p>  留言版面表note_comment: 記錄所有的留言版面的信息。</p><p>  版塊表note_comment2:版塊信息。</p><p>  后臺留言配置表note:對留言的某些信息進行配置,如留言URL地址、公

21、司名稱、主頁URL地址等,進行這些設置是為了盡可能最大地利用使用有限的資源,同時更有效地管理留言,對訪問留言的用戶量信息也有一個很好的記錄。</p><p>  用戶表users:記錄了用戶的基本且必要的信息。</p><p>  管理員表note_admin:記錄了管理員賬號、密碼、回復。</p><p>  設計數(shù)據(jù)表間的關系為雙層對應,就是簡單的針對某一留言管

22、理員進行回復</p><p><b>  4 編碼與實現(xiàn)</b></p><p><b>  4.1分析</b></p><p>  4.1.1數(shù)據(jù)庫表的設計</p><p>  設計數(shù)據(jù)庫表的字段時,需要充分考慮到留言的應用特點。數(shù)據(jù)庫表的設計要求簡單易于理解,擴展性好。 其中記錄留言發(fā)表文章的數(shù)

23、據(jù)庫表note_comment</p><p>  主要有以下的以下幾個描述字段:</p><p>  subject留言主題</p><p>  Name: 發(fā)貼者姓名</p><p>  Comment: 留言內(nèi)容</p><p>  Email: 郵箱地址</p><p

24、>  url: 主頁</p><p>  communication 其他聯(lián)系方式</p><p>  IP IP 地址</p><p>  PostDate 留言提交時間</p><p>  4.1.2數(shù)據(jù)庫的連接</p><p>  Access是文件型數(shù)

25、據(jù)庫,一個文件就是一個數(shù)據(jù)庫,可以利用ASP中的語法直接連接。在連接數(shù)據(jù)庫之前,必須先聲明一個對象來當作數(shù)據(jù)庫與ASP程序之間的媒介,具體連接方式如下:</p><p>  set rs=Server.CreateObject("ADODB.RecordSet")'創(chuàng)建RecordSet 對象 </p><p>  rs.open "select

26、 * from note_comment order by id desc",conn,1,3 '從數(shù)據(jù)庫中讀取留言,并保存在rs 中</p><p>  if rs.eof and rs.bof then '不存在留言記錄</p><p>  response.redirect "book_write.asp" 

27、9;轉到撰寫留言頁面</p><p>  else '存在記錄</p><p>  if counts=0 or counts="" then counts=10'每頁留言條數(shù) </p><p>  rs.pageSize = counts'每頁記錄數(shù)</p><

28、;p>  allpages = rs.pageCount'總頁數(shù)</p><p>  page = Request("page")'從瀏覽器取得當前頁 </p><p>  If not isNumeric(page) then page=1 'page不是數(shù)字</p><p>

29、  if isEmpty(page) or Cint(page) < 1 then'page 為空或小于1</p><p>  page = 1 </p><p>  elseif Cint(page) >= allPages then 'page 值大于總頁數(shù)</p><p>  page = allPages <

30、;/p><p><b>  end if </b></p><p>  rs.AbsolutePage = page'轉到某頁頭部 </p><p>  Do While Not rs.eof </p><p>  UserName=rs("Name")'用戶

31、名 </p><p>  Comments=rs("Comment")'內(nèi)容 </p><p>  Reply=rs("Reply")'回復 </p><p>  Usermail=rs("Email")'郵件 </p><p

32、>  url=rs("Url")'主頁 </p><p>  replyname = rs("ReplyName")'回復人姓名</p><p>  I=I+1'留言序號</p><p>  temp=RS.RecordCount-(page-1)*rs.

33、pageSize-I+1 </p><p><b>  %> </b></p><p>  在打開數(shù)據(jù)庫并完成相應的操作后,應關閉數(shù)據(jù)庫連接。當不再需要連接時將其關閉,可以減少對數(shù)據(jù)庫服務器的要求并可以使其他用戶能夠使用該連接。</p><p>  用Connection對象的Close方法終止Connection對象和數(shù)據(jù)庫之間的

34、連接。下面的腳本打開連接,然后將其關閉:</p><p><b>  <%</b></p><p><b>  End If</b></p><p>  conn.CLose'關閉數(shù)據(jù)庫</p><p>  Set conn = nothing</p&g

35、t;<p><b>  %></b></p><p><b>  4.2具體代碼實現(xiàn)</b></p><p><b>  數(shù)據(jù)添加</b></p><p>  rs.Addnew'添加一條記錄</p><p>  rs(&

36、quot;Name")=Request.Form("username")'姓名</p><p>  rs("Comment")=Request.Form("comments")'留言內(nèi)容</p><p>  rs("Email")=Request.For

37、m("usermail")'郵箱地址</p><p>  rs("url")=Request.Form("url")'主頁</p><p>  rs("Communication")=Request.Form("communication"

38、;)'其他聯(lián)系方式</p><p>  rs("IP")=Request.serverVariables("REMOTE_ADDR")'IP 地址</p><p>  rs("PostDate") = now()'留言提交時間</p><p&g

39、t;  rs("Subject") = Request.Form("subject")'留言主題</p><p>  rs.Update'更新數(shù)據(jù)庫</p><p><b>  數(shù)據(jù)刪除</b></p><p>  sub delfeedbac

40、k()'留言刪除</p><p>  if delid="" or isnull(delid) then'要刪除的記錄id 為空則給出提示</p><p>  response.write "<script>alert('操作失敗,沒有選擇合適參數(shù),請單擊“確定”返回!');</script>

41、"</p><p>  response.redirect "admin_main.asp"'返回到留言管理界面</p><p>  response.end</p><p>  else'id 存在</p><p>  '執(zhí)行數(shù)據(jù)庫中的刪除操作,刪除數(shù)據(jù)庫中id

42、 列的值在delid數(shù)組中的記錄</p><p>  conn.Execute("delete * from note_comment where ID in ("&delid&")")</p><p>  '刪除成功,給出提示</p><p>  response.write "<sc

43、ript>alert('留言刪除成功,請單擊“確定”返回!');</script>"</p><p>  response.redirect "admin_main.asp"'返回到留言管理界面</p><p>  response.end</p><p><b>  end

44、 if</b></p><p><b>  end sub</b></p><p>  <!--留言變量設置-基本變量設置頁面代碼--></p><p>  <!--#include file="conn.asp"--></p><p><b>  <

45、;%</b></p><p>  If Request.QueryString("action")="setup" then</p><p>  call setup()</p><p><b>  Else</b></p><p>  If Session("

46、;id")<>"" Then</p><p>  Set rs = server.createobject("ADODB.RecordSet")</p><p>  rs.Open "Select * from note_Admin where id="&Session("id")

47、,conn,1,3</p><p><b>  %> </b></p><p><b>  <%</b></p><p>  Sub setup()</p><p>  if request("save")="ok" then

48、'保存設置</p><p>  '創(chuàng)建RecordSet 對象</p><p>  Set NArs=Server.CreateObject("ADODB.Recordset")</p><p>  '從數(shù)據(jù)庫note_admin中查詢id 列的值為Session("id") 的記錄,并保存在NArs

49、中</p><p>  NArs.open "select * from note_admin where id="&Session("id"),conn,1,3</p><p>  '創(chuàng)建RecordSet 對象</p><p>  Set WBrs = Server.CreateObject("

50、ADODB.RecordSet")</p><p>  '從數(shù)據(jù)庫web 中查詢所有記錄,并保存在WBrs 中</p><p>  WBrs.Open "Select * from web",conn,1,3</p><p><b>  '資料填寫不完整</b></p><p&

51、gt;  if trim(request.form("sitename"))="" or trim(request.form("admin"))="" or trim(request.form("maxlength"))="" or trim(request.form("counts"))=&quo

52、t;" or trim(request.form("replycolor"))="" or trim(request.form("isreply"))="" or trim(request.form("distance"))="" then</p><p>  '給出提示,并返

53、回到前一頁</p><p>  response.write "<script>alert('資料填寫不完整或有錯誤,請檢查后重新提交。');history.back();</script>"</p><p>  response.end</p><p><b>  end if</b>

54、;</p><p>  '輸入的留言主題最大長度、留言內(nèi)容最大長度、每頁留言數(shù)和表格間距不是數(shù)字</p><p>  if (not isNumeric(request.form("subjectmaxlength"))) or (not isNumeric(request.form("maxlength"))) or (not isNume

55、ric(request.form("counts"))) or (not isNumeric(request.form("distance"))) then</p><p>  '給出提示,并返回到前一頁</p><p>  response.write "<script>alert('資料填寫不完整或有錯誤,請

56、檢查后重新提交。');history.back();</script>"</p><p>  response.end</p><p><b>  end if</b></p><p>  WBrs("sitename")=Request.Form("sitename")

57、'站點名稱</p><p>  NArs("admin")=Request.Form("admin")'管理員姓名</p><p>  if trim(request("password"))<>"" then </p><

58、p>  NArs("pwd")=trim(Request.Form("pwd"))'密碼</p><p><b>  End If</b></p><p>  WBrs("SubjectMaxLength") = Request.Form("subjectmaxlen

59、gth")'留言主題最大長度</p><p>  WBrs("maxlength")=Request.Form("maxlength")'留言內(nèi)容最大長度</p><p>  WBrs("counts")=Request.Form("counts")

60、'每頁留言數(shù)</p><p>  WBrs("mail")=Request.Form("mail")'是否必填郵箱</p><p>  NArs("isreply")=trim(Request.Form("isreply"))'回復提示&

61、lt;/p><p>  NArs("replycolor")=trim(Request.Form("replycolor"))'回復顏色</p><p>  WBrs("distance")=Request.Form("distance")'表格間距</p>

62、;<p>  NArs.update'更新數(shù)據(jù)庫</p><p>  WBrs.update'更新數(shù)據(jù)庫</p><p>  NArs.Close'關閉RecordSet 對象</p><p>  Set NArs = noth

63、ing</p><p>  WBrs.Close'關閉RecordSet 對象</p><p>  Set WBrs = nothing</p><p>  '保存成功,給出提示,并返回到管理選項界面</p><p>  response.write "<script>a

64、lert('您提交的設置已保存。');location.href='admin_set.asp';</script>"</p><p>  response.end</p><p><b>  End If</b></p><p><b>  End Sub</b>&

65、lt;/p><p>  conn.CLose'關閉數(shù)據(jù)庫連接</p><p>  Set conn = nothing</p><p><b>  %></b></p><p><b>  5 課程設計總結</b></p><p&g

66、t;  通過本次畢業(yè)設計,我熟練的掌握了開發(fā)程序的一些流程及規(guī)劃,在此特別感謝我的指導老師李老師,在他嚴格的要求下我懂得了開發(fā)軟件要有一種極其認真負責的態(tài)度。從學做這個在線留言系統(tǒng)中,體會到C#的簡單實用,也感受到編程的樂趣。編寫出了這個在線留言系統(tǒng),雖然有很多不足之處,但是我學到了更多的學習方法以及學習的態(tài)度。在以后道路上,這種困難是不可避免的。但我相信,這次的課程設計這將對我以后的工作和學習產(chǎn)生了很大的促進作用。無論做什么事都要大膽

67、的去想去做,這樣會有好的創(chuàng)意,才能更有作為。</p><p>  在這里我還要感謝我的同學,在學習上給了我很大的幫助。感謝所有協(xié)助我完成課程設計的朋友,有了你們的支持,才會讓我更加圓滿的完成此次課題的設計。</p><p><b>  參考文獻</b></p><p>  吉根林,崔海源《 Web程序設計》 電子工業(yè)出版社,2010.</

68、p><p>  2、相萬讓,趙怡,高愛乃《網(wǎng)頁設計與制作》2007. </p><p>  3、 庫少平,張毅《網(wǎng)頁設計基礎教程[M]》北京郵電大學出版社,2010</p><p>  4、 譚浩強《ASP程序設計》清華大學出版社,2000</p><p>  5、 王晟 韓澤坤編著《Access數(shù)據(jù)庫開發(fā)經(jīng)典案例解析[M]》清華大學出版社,2

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論