畢業(yè)設(shè)計——基于php的留言板的設(shè)計與實現(xiàn)(含外文翻譯)_第1頁
已閱讀1頁,還剩60頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p>  網(wǎng)絡(luò)留言板的設(shè)計與實現(xiàn)</p><p>  【摘要】設(shè)計并實現(xiàn)了一個基于B/S架構(gòu)的網(wǎng)絡(luò)留言板。該留言板系統(tǒng)采用PHP技術(shù)開發(fā),利用數(shù)據(jù)庫訪問技術(shù)實現(xiàn)對數(shù)據(jù)庫的各種操作,從而實現(xiàn)了留言板的留言及管理功能。在設(shè)計過程中遵循軟件開發(fā)流程,首先對系統(tǒng)功能作出需求分析,在此基礎(chǔ)上建立系統(tǒng)的應(yīng)用原型,然后進行了留言板系統(tǒng)的功能設(shè)計與實現(xiàn),經(jīng)過測試階段的反復(fù)調(diào)試和驗證不斷地修正和完善系統(tǒng)功能,最終達到符

2、合要求的可行系統(tǒng)。實現(xiàn)的具體功能包括用戶注冊、留言查看、留言簽寫、留言搜索及后臺管理等,并根據(jù)不同功能模塊面向的用戶對權(quán)限進行了合理劃分。</p><p>  【關(guān)鍵詞】留言板;PHP;數(shù)據(jù)庫;MySQL</p><p>  Design and Implementation of Message Boards</p><p>  Abstract: A inter

3、net message board based on B / S structure is designed and implemented. The message board system is developed with the PHP language, makes use of the database access technology for database operations, in order to achiev

4、e the leaving words function and management function. Following the software development processes during the design process, first of all the requirement analysis is made for the system. Based on this the system applica

5、tion prototype is established, and then the</p><p>  Key words:Message boards; PHP; Database; MySQL</p><p><b>  引言</b></p><p>  由于Internet技術(shù)持續(xù)而飛速的發(fā)展,給人們各個方面帶來了巨大變化,尤其對傳統(tǒng)

6、的交流方式提出了新的模式和要求,由此而誕生的網(wǎng)絡(luò)留言板系統(tǒng)在Internet應(yīng)用上的地位顯而易見。網(wǎng)絡(luò)留言板系統(tǒng)利用網(wǎng)絡(luò)一定的時效性和廣泛的傳播面,可以方便人與人之間的信息交流和互動。它已成為現(xiàn)代網(wǎng)絡(luò)信息化建設(shè)中的重要組成部分,從而備受人們的重視。</p><p>  最初,留言只是用于發(fā)布公告系統(tǒng),討論問題的在線交流平臺;但現(xiàn)在的網(wǎng)絡(luò)留言板已經(jīng)不再是以一個留言板的形式獨立地呈現(xiàn)給用戶留言,隨著網(wǎng)絡(luò)的普及,留言的

7、功能越來越豐富,受到廣大網(wǎng)民的歡迎。留言板已被作為一種網(wǎng)站系統(tǒng)的留言功能模塊嵌入到一些需要留言功能的網(wǎng)站系統(tǒng)中,從而減少了網(wǎng)站留言功能模塊的開發(fā),像企業(yè)、學(xué)校等單位可以利用網(wǎng)上的留言發(fā)布公告、通知等。因此留言板在未來的網(wǎng)站系統(tǒng)中是不可缺少的一部分。對于一般企業(yè)而言,網(wǎng)絡(luò)留言系統(tǒng)能夠通過網(wǎng)絡(luò)提供方便的日常信息管理和交互,同時只需要相對較低廉的建設(shè)和維護成本。另外,企業(yè)還可以通過網(wǎng)絡(luò)留言板,為客戶提供一個跨地域的交流平臺,以便及時了解和掌握

8、客戶需求,加強企業(yè)與客戶之間的溝通,提高企業(yè)的市場競爭力。</p><p>  借助于留言板可以方便和朋友的聯(lián)系,加強朋友之間的感情交流,可以方便的查閱各種資料,可以提高獲取信息的隨機性,促進信息和技術(shù)的交流,還可以為用戶提供一個休閑的聚會空間,以此來增加網(wǎng)站的人氣,維持穩(wěn)定數(shù)目的訪問群體。因此,本次開發(fā)留言板系統(tǒng)旨在探索尋求一種以互聯(lián)網(wǎng)為基礎(chǔ)的開放模式,更好的方便人們?nèi)粘P畔⒌臏贤ā?lt;/p>&l

9、t;p><b>  1 系統(tǒng)分析</b></p><p>  隨著互聯(lián)網(wǎng)的高速發(fā)展,越來越多的人們都在網(wǎng)上建立起了自己的留言板,很多留言板為我們的日常生活提供了很大的幫助,展示了強大的媒體優(yōu)勢,留言板的作用越來越受到重視,已經(jīng)成為了大家信息溝通,技術(shù)交流不可或缺的工具。要開發(fā)網(wǎng)絡(luò)留言板,首先應(yīng)掌握它的用戶需求,理清它的功能結(jié)構(gòu),然后才能夠有依有據(jù)的進行功能模塊的劃分,開發(fā)環(huán)境的選擇,進

10、而進行整個系統(tǒng)的代碼實現(xiàn)。</p><p><b>  1.1可行性分析</b></p><p>  網(wǎng)絡(luò)留言板可以為用戶和企業(yè)提供一個具有更好互動性的交流平臺,方便企業(yè)快速獲取來自不同層次用戶的反饋信息,并可以更有效地處理這些反饋信息,從而減少花費到這方面的大量時間,提高經(jīng)濟管理效率。</p><p>  網(wǎng)站開發(fā)近年來呈現(xiàn)飛速發(fā)展,已形成現(xiàn)

11、在的以asp,jsp,asp.net,php開發(fā)語言和開發(fā)平臺,各個軟件公司相繼投入研發(fā)人員不斷的改進產(chǎn)品,因此從技術(shù)上講已經(jīng)具有成熟的環(huán)境。因php簡單易學(xué),開發(fā)速度快的特點。為了盡快開發(fā)出這個留言板,我選擇用php進行開發(fā)。</p><p><b>  1.2需求分析</b></p><p>  在網(wǎng)絡(luò)高速發(fā)展的今天,網(wǎng)絡(luò)留言板給人們提供了良好的互動溝通的平臺。使

12、用網(wǎng)絡(luò)留言板的網(wǎng)民人數(shù)眾多,使得網(wǎng)絡(luò)留言板的留言內(nèi)容豐富多樣,人們可以通過網(wǎng)絡(luò)留言板討論工作、學(xué)習(xí)、生活和娛樂,以及對留言內(nèi)容和對事物進行評論,從而在網(wǎng)上建立一個任何人都可以參與的互動天地,網(wǎng)絡(luò)留言板已成為當今網(wǎng)絡(luò)最為多元化和平民化的互動交流的空間和平臺。對于網(wǎng)民,只要有網(wǎng)絡(luò)留言板,就可以超越現(xiàn)實生活,擁有不同以往的全新網(wǎng)上生活。</p><p>  網(wǎng)絡(luò)留言板的形式相對簡單,大體上可分為留言和留言管理兩部分,它

13、雖然簡單無比,但卻逐漸成為一種新的網(wǎng)絡(luò)應(yīng)用模式,它一出現(xiàn)便獲得了很多人的支持和參與。網(wǎng)絡(luò)發(fā)展前景無限,及早與網(wǎng)絡(luò)結(jié)合,與信息時代同步,與高科技匯合,定會給社會各行各業(yè)的發(fā)展注入新鮮的活力。站在網(wǎng)絡(luò)時代的前夜,我們清晰地聽到了網(wǎng)絡(luò)時代的宣言,誰掌握了網(wǎng)絡(luò),誰就掌握了未來?,F(xiàn)對于互聯(lián)網(wǎng)日益增長的用戶群來說,網(wǎng)絡(luò)留言板會有相當大的需求。</p><p>  1.2.1系統(tǒng)設(shè)計目標</p><p>

14、;  網(wǎng)絡(luò)留言板的設(shè)計目標實現(xiàn)以下功能:新用戶注冊功能、用戶登錄功能、登錄用戶發(fā)表留言功能、登錄用戶查看留言并給管理員留悄悄話的功能、管理員登錄功能、管理員回復(fù)留言功能、管理員刪除留言功能、管理員發(fā)布系統(tǒng)公告功能和管理員添加敏感詞的功能。</p><p>  1.2.2系統(tǒng)功能分析</p><p>  開發(fā)一個留言板系統(tǒng),首先應(yīng)確定留言板的功能,最基本的留言板需要實現(xiàn)的功能很簡單,一般有用

15、戶查看留言,發(fā)表留言;管理員查看留言,回復(fù)留言和刪除留言。屬于用戶的業(yè)務(wù)操作有檢索留言、查看留言和發(fā)表留言,留言管理者的業(yè)務(wù)操作相對用戶要多一項,即管理留言,包括回復(fù)留言和刪除留言等操作。</p><p>  本系統(tǒng)將要實現(xiàn)的留言板是在最基本的留言板的功能的基礎(chǔ)上進行擴展,實現(xiàn)一個高級的網(wǎng)絡(luò)留言板。</p><p>  前臺功能需求:用戶登錄、用戶注冊、留言查看、留言檢索、顯示系統(tǒng)公告和簽

16、寫留言等。其中,在留言查看模塊中要實現(xiàn)查看全部留言、分頁瀏覽留言及管理員回帖顯示等功能,在簽寫留言模塊中要實現(xiàn)敏感詞過濾、給管理管理員悄悄話、支持圖像和表情以及支持驗證碼等功能。</p><p>  后臺功能需求:管理員登錄、留言管理、公告發(fā)布與管理和敏感詞添加與管理。其中,留言管理要實現(xiàn)查看留言、回復(fù)留言、刪除留言及查找留言等功能。</p><p>  2 系統(tǒng)開發(fā)工具及環(huán)境</p

17、><p>  系統(tǒng)開發(fā)環(huán)境的選擇對于系統(tǒng)的建立來說至關(guān)重要,它將決定著系統(tǒng)開發(fā)工作量的大小,系統(tǒng)性能特點以及系統(tǒng)今后維護工作的易難等。因此在開發(fā)系統(tǒng)之前,根據(jù)對系統(tǒng)所采用的技術(shù)、實現(xiàn)功能的評估,在選擇開發(fā)環(huán)境時,主要考慮了一下幾個因素:擴展性、總體成本、功能、是否容易開發(fā)和管理,另外開放性和互操作性也是需要考慮的一個重要方面,因為該系統(tǒng)是運行在Internet上的,用戶平臺的差異性決定了與其他系統(tǒng)的互操作是不可避免的

18、。</p><p>  2.1 MVC三層構(gòu)架</p><p>  MVC是Model-View-Controller的簡寫,“Model”代表的是應(yīng)用的業(yè)務(wù)邏輯,“View”是應(yīng)用的表面,“Controller”是提供應(yīng)用的處理工程控制,通過這種設(shè)計模型把應(yīng)用邏輯,吃力過程和顯示邏輯分成不同的組件實現(xiàn)。這些組件可以進行交互和重用。</p><p><b>

19、;  2.2開發(fā)工具簡介</b></p><p>  以簡單、易用和免費為出發(fā)點,本系統(tǒng)將選用PHP作為開發(fā)語言,選用Apache作為系統(tǒng)調(diào)試的Web服務(wù)器,數(shù)據(jù)庫選用MySQL。</p><p>  2.2.1 PHP簡介</p><p>  PHP是服務(wù)器端的一種編程語言,是為了創(chuàng)建HTML內(nèi)容而設(shè)計的既簡單游強大的語言。PHP和其他的編程語言類似,

20、使用變量存儲臨時數(shù)值,使用運算符操作變量。PHP的真正價值在于它是一個應(yīng)用程序服務(wù)器。</p><p>  PHP起源于自由軟件,即開放源代碼軟件,使用PHP進行Web應(yīng)用程序的開發(fā)具有以下語言優(yōu)勢。</p><p>  安全性高:PHP是開源軟件,每個人都可以看到所有PHP的源代碼,程序代碼與Apache編譯在一起的范式也可以讓它具有靈活的安全設(shè)定,PHP具有了公認的安全性能。</

21、p><p>  跨平臺:PHP幾乎支持所有的操作系統(tǒng)平臺并且支持Apache、IIS等多種Web服務(wù)器,并以此廣為流行。</p><p>  支持廣泛的數(shù)據(jù)庫:可操作多種主流與非主流的數(shù)據(jù)庫,如MySQL、Access、SQL Server、Oracle、DB2等,其中PHP與MySQL是現(xiàn)在最佳的組合,它們的組合可以跨平臺運行。</p><p>  簡單易學(xué):PHP嵌

22、入在HTML語言中,以腳本語言為主,內(nèi)置豐富函數(shù),語法簡單、書寫容易、方便學(xué)習(xí)掌握。</p><p>  執(zhí)行速度快:占用系統(tǒng)資源少,代碼執(zhí)行速度快。</p><p>  模板化:實現(xiàn)程序邏輯與用戶界面分離。</p><p>  支持面向?qū)ο螅褐С置嫦驅(qū)ο蠛瓦^程的兩種風(fēng)格開發(fā),并可向下兼容。</p><p>  開發(fā)成本低:在流行的企業(yè)應(yīng)用L

23、AMP平臺中,Linux、Apache、MySQL和PHP都是免費軟件,這種開源免費的框架結(jié)構(gòu)可以為網(wǎng)站經(jīng)營者節(jié)省很大一筆開支。</p><p>  內(nèi)嵌Zend加速引擎,性能穩(wěn)定快速。</p><p>  應(yīng)用范圍廣:PHP技術(shù)在Web開發(fā)的各個方面應(yīng)用的非常廣泛,世界上很多大公司都采用了PHP技術(shù)。</p><p>  2.2.2 Apache簡介</p&

24、gt;<p>  Apache是世界使用排名第一的Web服務(wù)器軟件。它可以運行在幾乎所有廣泛使用的計算機平臺上。Apache源于NCSAhttpd服務(wù)器,經(jīng)過多次修改,成為世界上最流行的Web服務(wù)器軟件之一。Apache的特點是簡單、速度快、性能穩(wěn)定,并可做代理服務(wù)器來使用。Apache web服務(wù)器軟件擁有以下特性:</p><p>  支持最新的HTTP/1.1通信協(xié)議;</p>

25、<p>  擁有簡單而強有力的機遇文件的配置過程;</p><p><b>  支持通用網(wǎng)關(guān)接口;</b></p><p>  支持基于IP和基于域名的虛擬主機;</p><p>  支持多種方式的HTTP認證;</p><p>  集成Perl處理模塊;</p><p>  集成代理服

26、務(wù)器模塊;</p><p>  支持實時監(jiān)視服務(wù)器狀態(tài)和定制服務(wù)器日志;</p><p>  支持服務(wù)器端包含指令(SSI);</p><p>  支持安全Socket層(SSL);</p><p>  提供用戶會話過程的跟蹤;</p><p>  2.2.3 MySQL數(shù)據(jù)庫簡介</p><p&g

27、t;  MySQL是一個真正的多用戶、多線程SQL數(shù)據(jù)庫服務(wù)器。SQL(結(jié)構(gòu)化查詢語言)是世界上最流行的和標準化的數(shù)據(jù)庫語言。MySQL是以一個客戶機/服務(wù)器結(jié)構(gòu)的實現(xiàn),它由一個服務(wù)器守護程序mysqld和很多不同的客戶程序和庫組成。</p><p>  SQL是一種標準化的語言,它使得存儲、更新和存取信息更容易。例如,你能用SQL語言為一個網(wǎng)站檢索產(chǎn)品信息及存儲顧客信息,同時MySQL也足夠快和靈活以允許你存儲

28、記錄文件和圖像。</p><p>  MySQL 主要目標是快速、健壯和易用。最初是因為我們需要這樣一個SQL服務(wù)器,它能處理與任何可不昂貴硬件平臺上提供數(shù)據(jù)庫的廠家在一個數(shù)量級上的大型數(shù)據(jù)庫,但速度更快,MySQL就開發(fā)出來。自1996年以來,我們一直都在使用MySQL,其環(huán)境有超過 40 個數(shù)據(jù)庫,包含 10,000個表,其中500多個表超過7百萬行,這大約有100 個吉字節(jié)(GB)的關(guān)鍵應(yīng)用數(shù)據(jù)。</

29、p><p>  MySQL建立的基礎(chǔ)是業(yè)已用在高要求的生產(chǎn)環(huán)境多年的一套實用例程。盡管MySQL仍在開發(fā)中,但它已經(jīng)提供一個豐富和極其有用的功能集。</p><p>  MySQL 最早起始于 1979 年,開始是 Michael “Monty” Widenius 為瑞典的 TcX 公司創(chuàng)建的 UNIREG 數(shù)據(jù)庫工具。1994 年,TcX 開始尋找一個用來開發(fā) Web 應(yīng)用程序的 SQL 服

30、務(wù)器。他們測試了一些商業(yè)服務(wù)器,但是發(fā)現(xiàn)所有服務(wù)器對于 TcX 的大型表來說都太慢。他們也試了 mSQL,但它缺乏 TcX 需要的某些功能。因此,Monty 開始開發(fā)一種新的服務(wù)器。其編程接口明確地設(shè)計為類似 mSQL 的編程接口,因為 mSQL 可得到幾個免費的工具,所以利用與 mSQL 類似的接口,可以將這些相同的工具用于MySQL 從而大大減少了開發(fā)接口的工作。</p><p>  1995 年,Detro

31、n HB公司的 David Axmark 努力爭取 TcX公司在因特網(wǎng)上發(fā)布 MySQL。David 還做了文檔資料方面的工作和使 MySQL 與 GNU 的配置實用程序一起建造的工作。MySQL 3.11.1 在 1996 年以用于 Linux 和 Solaris 系統(tǒng)的二進制分發(fā)形式發(fā)布。今天,MySQL 正工作在許多平臺上,并且二進制和源代碼的形式都可以得到。</p><p>  MySQL 并不是一個開放

32、源代碼的產(chǎn)品,因為在某些條件下使用它需要許可證。但是,MySQL 很愿意在開放源代碼的團體內(nèi)得以普及,因為“認證”這個術(shù)語并不是非常有約束力的(除非通過出售 MySQL 或出售需要它的服務(wù)來掙錢,否則,大體上說 MySQL 一般是免費的)。</p><p>  MySQL 的普及并不限于開放源代碼團體內(nèi)。雖然它在個人計算機上運行(確實,MySQL 的開發(fā)一般在不昂貴的 Linux 系統(tǒng)上進行),但它是可移植的,并

33、且運行在商用操作系統(tǒng)(如 Solaris、Irix 和 Windows)和一直到企業(yè)服務(wù)器的各種硬件上。此外,它的性能也足以和任何其他系統(tǒng)相匹敵,而且它還可以處理具有數(shù)百萬個記錄的大型數(shù)據(jù)庫。</p><p>  MySQL 的廣泛應(yīng)用前景在我們面前尚未完全展開,如運行在功能強但不昂貴的硬件上的免費可用操作系統(tǒng),將豐富的處理功能和能力提供給比以往更多的人,在比過去范圍更廣的系統(tǒng)上運行等等。信息處理的經(jīng)濟障礙的降低

34、使強有力的數(shù)據(jù)庫解決方案到達了比過去任何時候更多的人和機構(gòu)的手中。例如,本人在運行 LinuxPPC 的 G3 PowerBook 筆記本電腦上使用 MySQL 與 Perl、Apache 和 PHP,這允許本人在任何地方都可以進行工作,總的成本只是 PowerBook 的成本。</p><p>  過去只能夢想將高性能的 RDBMS 用于自己工作的機構(gòu),現(xiàn)在可以這樣做了,并且開銷很低。數(shù)據(jù)庫的利用在單一的層次上

35、也在不斷地增加。過去從未想過要使用數(shù)據(jù)庫的人現(xiàn)在也開始考慮一旦得到一個數(shù)據(jù)庫,怎樣將其用于自己的各種目的,例如用來存儲和訪問系統(tǒng)的研究結(jié)果,跟蹤和維護最喜愛的收藏物(蝴蝶、郵票、捧球明星卡等等),幫助管理新開張的公司,或者提供個人 Web 站點的搜索能力。</p><p><b>  2.3開發(fā)模式</b></p><p>  網(wǎng)站建設(shè)目前主要有兩種基本的開發(fā)模型:兩

36、層模型、三層模型。B/S結(jié)構(gòu)是真正的三層結(jié)構(gòu),它以訪問WEB數(shù)據(jù)庫為中心,HTTP為傳輸協(xié)議,客戶端通過瀏覽器(Browser)訪問WEB服務(wù)器和與其相連的后臺數(shù)據(jù)庫,我們稱之為B/S(Browser/Server)模式。其三級結(jié)構(gòu)組成如圖2.3所示:</p><p>  圖2.3 開發(fā)模式圖</p><p>  圖中從左到右,分為三個層次:</p><p>  第

37、一層是客戶端即瀏覽器,主要完成客戶和后臺的交互及最終查詢結(jié)果的輸出功能。在客戶端向指定的Web服務(wù)器提出服務(wù)器請求,Web服務(wù)器用HTTP協(xié)議把所需文件資料傳給用戶,客戶端接受并顯示在WWW瀏覽器上;</p><p>  第二層Web服務(wù)器是功能層,完成客戶的應(yīng)用功能,即Web服務(wù)器接受客戶請求,并與后臺數(shù)據(jù)庫連接,進行申請?zhí)幚恚缓髮⑻幚斫Y(jié)果返回Web服務(wù)器,再傳至客戶端;</p><p&g

38、t;  第三層數(shù)據(jù)庫服務(wù)器是數(shù)據(jù)層。數(shù)據(jù)庫服務(wù)器應(yīng)客戶請求獨立地進行各種處理。</p><p>  與傳統(tǒng)的C/S模式相比,B/S結(jié)構(gòu)把處理功能全部移植到了服務(wù)器端,用戶的請求通過瀏覽器發(fā)出,無論是使用和數(shù)據(jù)庫維護上都比傳統(tǒng)模式更加經(jīng)濟方便。而且使維護任務(wù)層次化:管理員負責(zé)服務(wù)器硬件日常管理和維護,系統(tǒng)維護人員負責(zé)后臺數(shù)據(jù)庫數(shù)據(jù)更新維護。</p><p><b>  2.4系統(tǒng)開

39、發(fā)環(huán)境</b></p><p>  系統(tǒng)能夠順利開發(fā)完成,好的開發(fā)環(huán)境是必要的。該系統(tǒng)使用的開發(fā)環(huán)境如下。</p><p><b>  服務(wù)器端</b></p><p>  操作系統(tǒng):Windows Server 2003。</p><p>  服務(wù)器:Apache 2.0。</p><p

40、>  PHP軟件:PHP 5.0。</p><p>  數(shù)據(jù)庫:MySQL 5.0</p><p>  MySQL圖形化管理軟件:phpMySQLAdmin-2.9.0.2。</p><p><b>  瀏覽器:IE8.0</b></p><p><b>  客戶端</b></p>

41、<p>  瀏覽器:推薦使用IE6.0及以上版本。</p><p><b>  3 系統(tǒng)概要設(shè)計</b></p><p><b>  3.1模塊設(shè)計</b></p><p>  經(jīng)過系統(tǒng)的功能分析可以明確的知道,網(wǎng)絡(luò)留言板的功能分為普通用戶的前臺功能和留言管理的后臺功能兩部分,因此模塊也分為兩部分進行設(shè)計。網(wǎng)

42、絡(luò)留言板的模塊體系如圖3.1所示。</p><p>  網(wǎng)絡(luò)留言系統(tǒng)主要包括以下功能模塊:</p><p>  查看留言功能模塊:供用戶查看及瀏覽留言;</p><p>  簽寫留言功能模塊:用戶簽寫留言、過濾留言敏感詞、給管理員悄悄話;</p><p>  文章查看功能模塊:用戶可查看管理員發(fā)表的文章;</p><p&g

43、t;  最新留言列表顯示功能模塊:用戶可以瀏覽最新的留言;</p><p>  用戶注冊功能模塊:供需要留言的用戶注冊賬號;</p><p>  管理員登錄功能模塊:管理員登錄;</p><p>  留言管理功能模塊:管理留言、查找留言、回復(fù)留言、管理管理員私貼;</p><p>  公告功能模塊:公告的發(fā)表、公告瀏覽、公告刪除;</p

44、><p>  敏感詞管理功能模塊:添加敏感詞、讀取敏感詞。</p><p>  圖3.1 網(wǎng)絡(luò)留言板的模塊體系</p><p>  3.2留言板系統(tǒng)流程</p><p>  系統(tǒng)的各個功能模塊已確定,接下來要做的是分析清楚各個模塊之間的流程關(guān)系,將各個功能模塊串聯(lián)起來,使得模塊之間有關(guān)聯(lián)的關(guān)系,這樣才能構(gòu)成一個完整的系統(tǒng)。</p>

45、<p>  首先簽寫留言信息,然后對留言內(nèi)容進行敏感詞過濾,如果提交成功,則將留言信息顯示在前臺首頁,最后由管理員對留言信息進行綜合管理。管理員對留言進行管理之前先要登錄,登錄成功后進入后臺的留言管理頁面。留言板的系統(tǒng)流程如圖3.2所示。</p><p>  圖3.2 網(wǎng)絡(luò)留言板系統(tǒng)流程</p><p><b>  4 數(shù)據(jù)庫設(shè)計</b></p>

46、<p>  4.1數(shù)據(jù)庫需求分析</p><p>  本系統(tǒng)的主要實體有:用戶信息實體、留言信息實體、留言回復(fù)信息實體、文章信息實體。各實體之間的關(guān)系E-R圖如圖4.1所示。</p><p>  圖4.1 網(wǎng)上留言系統(tǒng)E-R圖</p><p>  4.2數(shù)據(jù)庫概念結(jié)構(gòu)設(shè)計</p><p>  數(shù)據(jù)庫邏輯設(shè)計將所有實體和關(guān)系轉(zhuǎn)換成

47、一個系列的關(guān)系模式,將圖4.1中數(shù)據(jù)庫E-R圖轉(zhuǎn)換成為關(guān)系模型。</p><p>  用戶:(用戶編號,用戶名,昵稱,密碼)</p><p>  留言信息:(留言編號,留言昵稱,留言主題,留言內(nèi)容,留言心情,留言時間,用戶頭像,回復(fù)標記,私貼標記)</p><p>  留言回復(fù)信息:(留言編號,留言昵稱,留言主題,留言內(nèi)容,留言心情)</p><

48、p>  公告信息:(公告編號,公告主題,心情,公告內(nèi)容,發(fā)布日期)</p><p>  4.3數(shù)據(jù)庫邏輯結(jié)構(gòu)設(shè)計</p><p>  根據(jù)數(shù)據(jù)項,可以設(shè)計出滿足需求的各種實體,以及它們之間的關(guān)系。這樣本系統(tǒng)設(shè)計一下實體:用戶、留言、留言回復(fù)和公告。這幾種實體對應(yīng)數(shù)據(jù)庫中的4個表:tb_user、tb_note、tb_note_answer和tb_fil,每個表與邏輯設(shè)計中一種關(guān)系模型

49、對應(yīng)。下面是每個數(shù)據(jù)表中的屬性,包括屬性列的名稱,數(shù)據(jù)類型,長度等內(nèi)容。</p><p>  經(jīng)過上面對系統(tǒng)功能的分析和需求總結(jié),設(shè)計出如下所示的數(shù)據(jù)項:</p><p>  用戶,包括用戶編號、用戶名、昵稱和密碼。用戶信息及屬性如圖4.2所示。</p><p>  圖4.2 用戶實體屬性圖</p><p>  tb_user表:tb_use

50、r表用來存儲用戶的ID、用戶名、昵稱及密碼,如表4.1所示,主鍵是在一個表上定義的唯一鍵中的一個,而且一個表上只能有一個主鍵。</p><p>  表4.1 用戶信息數(shù)據(jù)表</p><p>  留言,包括留言編號、留言昵稱、留言主題、留言內(nèi)容、留言心情、留言時間、用戶頭像、回復(fù)標記和私貼標記。留言信息及屬性如圖4.3所示。</p><p>  圖4.3 留言實體屬性

51、圖</p><p>  tb_note表:tb_note表用來存儲留言的留言編號、留言昵稱、留言主題、留言內(nèi)容、留言心情、留言時間、用戶頭像、回復(fù)標記及私貼標記,留言信息及屬性如表4.2所示。</p><p>  表4.2留言信息數(shù)據(jù)表</p><p>  回復(fù),包括留言編號、留言昵稱、留言主題、留言內(nèi)容和留言心情?;貜?fù)信息及屬性如圖4.4所示。</p>

52、<p>  圖4.4 留言回復(fù)實體屬性圖</p><p>  tb_note_answer表:tb_note_answer表用來存儲留言編號、留言昵稱、留言主題、留言內(nèi)容和留言心情,回復(fù)信息及屬性如表4.3所示。</p><p>  表4.3 回復(fù)信息數(shù)據(jù)表</p><p>  公告,包括公告編號、公告主題、心情、公告內(nèi)容和發(fā)布日期。公告信息及屬性如圖

53、4.5所示。</p><p>  圖4.5 文章實體實體屬性圖</p><p>  tb_file表:tb_file表用來存儲系統(tǒng)公告的編號、公告主題、心情、公告內(nèi)容和發(fā)布日期,公告的信息及屬性如表4.4所示。</p><p>  表4.4 文章信息表</p><p><b>  5 系統(tǒng)詳細設(shè)計</b></p&g

54、t;<p><b>  5.1數(shù)據(jù)庫的連接</b></p><p>  為了便于維護,減少代碼冗余,在數(shù)據(jù)庫連接這部分,采用面向?qū)ο蟮姆绞?,定義了一個數(shù)據(jù)庫訪問類DB_MySQL。定義數(shù)據(jù)庫訪問類的代碼如下。</p><p><b>  <?php</b></p><p>  /************

55、********************************</p><p><b>  *數(shù)據(jù)庫訪問類</b></p><p>  *********************************************/</p><p>  class DB_MySQL{</p><p>  //=======

56、===================</p><p>  var $Host = "127.0.0.1";//服務(wù)器地址</p><p>  var $Database = "db_leaveword";//數(shù)據(jù)庫名稱</p><p>  var $User = "root";//用戶

57、名</p><p>  var $Password = "root";//用戶密碼</p><p>  //==========================</p><p>  var $Link_ID = 0;//數(shù)據(jù)庫連接</p><p>  var $Query_ID = 0;//查詢

58、結(jié)果</p><p>  var $Row_Result = array();//結(jié)果集組成的數(shù)組</p><p>  var $Field_Result = array();//結(jié)果集字段名組成的數(shù)組</p><p>  var $Affected_Rows;//影響的行數(shù)</p><p>  var $Rows;

59、//結(jié)果集中記錄行數(shù)</p><p>  var $Fields;//結(jié)果集中字段個數(shù)</p><p>  var $Row_Position = 0;//記錄指針位置索引</p><p>  //*******************************************************</p><

60、p>  /*** 構(gòu)造函數(shù) */</p><p>  function __construct(){</p><p>  $this->connect();</p><p><b>  }</b></p><p>  /*** 解析函數(shù) */</p><p>  function __

61、destruct(){</p><p>  mysql_close($this->Link_ID);</p><p><b>  }</b></p><p>  /*** 連接服務(wù)器,選擇數(shù)據(jù)庫 */</p><p>  function connect($Database = "",$Host

62、 = "",$User = "",$Password = ""){</p><p>  if ("" == $Database){</p><p>  $Database = $this->Database;</p><p><b>  }</b></p

63、><p>  if ("" == $Host){</p><p>  $Host = $this->Host;</p><p><b>  }</b></p><p>  if ("" == $User){</p><p>  $User

64、= $this->User;</p><p><b>  }</b></p><p>  if ("" == $Password){</p><p>  $Password = $this->Password;</p><p><b>  }</b></p>

65、;<p>  if ( 0 == $this->Link_ID )</p><p><b>  {</b></p><p>  $this->Link_ID=@mysql_pconnect($Host, $User, $Password);</p><p>  if (!$this->Link_ID)</p

66、><p><b>  {</b></p><p>  $this->halt("連接數(shù)據(jù)庫服務(wù)端失敗!");</p><p><b>  }</b></p><p>  if (!mysql_select_db($this->Database,$this->Link

67、_ID))</p><p><b>  {</b></p><p>  $this->halt("不能打開指定的數(shù)據(jù)庫:".$this->Database);</p><p><b>  }</b></p><p><b>  }</b><

68、/p><p>  return $this->Link_ID;</p><p><b>  }</b></p><p>  /*** 釋放內(nèi)存 */</p><p>  function free(){</p><p>  if ( @mysql_free_result($this->Qu

69、ery_ID) )</p><p>  unset ($this->Row_Result);</p><p>  $this->Query_ID = 0;</p><p><b>  }</b></p><p>  /*** 執(zhí)行查詢 */</p><p>  function que

70、ry($Query_String){</p><p>  /* 釋放上次查詢占用的內(nèi)存 */</p><p>  if ($this->Query_ID){</p><p>  $this->free();</p><p><b>  }</b></p><p>  if(0 == $

71、this->Link_ID){</p><p>  $this->connect();</p><p><b>  }</b></p><p><b>  //設(shè)置中文字符集</b></p><p>  @mysql_query("set names gb2312",

72、$this->Link_ID);</p><p>  $this->Query_ID = @mysql_query($Query_String,$this->Link_ID);</p><p>  if (!$this->Query_ID){</p><p>  $this->halt("SQL查詢語句出錯: ".$

73、Query_String);</p><p><b>  }</b></p><p>  return $this->Query_ID;</p><p><b>  }</b></p><p>  /*** 返回結(jié)果集記錄組成的數(shù)組 */</p><p>  funct

74、ion get_rows_array(){</p><p>  $this->get_rows();</p><p>  for($i=0;$i<$this->Rows;$i++){</p><p>  if(!mysql_data_seek($this->Query_ID,$i)){</p><p>  $this-

75、>halt("mysql_data_seek查詢語句出錯");//調(diào)用自定義函數(shù)</p><p><b>  }</b></p><p>  $this->Row_Result[$i] = mysql_fetch_array($this->Query_ID);</p><p><b>  }&

76、lt;/b></p><p>  return $this->Row_Result;</p><p><b>  }</b></p><p>  /*** 返回結(jié)果集字段組成的數(shù)組 */</p><p>  function get_fields_array(){</p><p>  

77、$this->get_fields();</p><p>  for($i=0;$i<$this->Fields;$i++){</p><p>  $obj = mysql_fetch_field($this->Query_ID,$i);</p><p>  $this->Field_Result[$i] = $obj->name

78、;</p><p><b>  }</b></p><p>  return $this->Field_Result;</p><p><b>  }</b></p><p>  /*** 返回結(jié)果集中記錄行數(shù) */</p><p>  function get_row

79、s(){</p><p>  $this->Rows = mysql_num_rows($this->Query_ID);</p><p>  return $this->Rows;</p><p><b>  }</b></p><p>  /*** 返回結(jié)果集中字段個數(shù) */</p>

80、<p>  function get_fields(){</p><p>  $this->Fields = mysql_num_fields($this->Query_ID);</p><p>  return $this->Fields;</p><p><b>  }</b></p><p&

81、gt;  /*** 執(zhí)行SQL語句并返回由查詢結(jié)果中第一行記錄組成的數(shù)組 */</p><p>  function fetch_one_array($sql){</p><p>  $this->query($sql);</p><p>  return mysql_fetch_array($this->Query_ID);</p>&l

82、t;p><b>  }</b></p><p>  /*** 打印錯誤信息 */</p><p>  function halt($msg){</p><p>  $this->Error=mysql_error();</p><p>  printf("<BR><b>數(shù)據(jù)庫

83、發(fā)生錯誤:</b> %s<br>\n", $msg);</p><p>  printf("<b>MySQL 返回錯誤信息:</b> %s <br>\n",$this->Error);</p><p><b>  }</b></p><p><

84、;b>  }</b></p><p><b>  ?></b></p><p>  在這個類中,定義了一個connect()函數(shù)用來連接數(shù)據(jù)庫服務(wù)器并選擇數(shù)據(jù)庫,函數(shù)query()的功能為執(zhí)行查詢數(shù)據(jù)庫。</p><p><b>  5.2首頁設(shè)計</b></p><p> 

85、 首頁是整個網(wǎng)絡(luò)留言板的入口地址,合理的首頁布局和模塊分配直接影響到用戶對留言板的第一印象。為了吸引更多的用戶瀏覽和使用網(wǎng)絡(luò)留言板,在系統(tǒng)開發(fā)時需要精心地對首頁進行設(shè)計。</p><p>  本系統(tǒng)在頁面設(shè)計上采用傳統(tǒng)的排版方式,主要有首部導(dǎo)航欄、左側(cè)顯示區(qū)和主顯示區(qū)3部分組成,如圖5.1所示。</p><p>  首部導(dǎo)航欄:包括留言簽寫鏈接、管理留言鏈接及用戶注冊鏈接。</p&g

86、t;<p>  左側(cè)顯示區(qū):包括用戶登錄、文章顯示、檢索留言、最新留言等模塊。</p><p>  主顯示區(qū):為留言瀏覽和顯示等信息。</p><p>  圖5.1 網(wǎng)絡(luò)留言板首頁</p><p>  5.3用戶登錄模塊的實現(xiàn)</p><p>  用戶登錄模塊設(shè)計在首頁中,使用戶在需要留言時能夠快捷方便地登錄。當用戶輸入用戶名和

87、密碼并登錄成功后,用戶登錄模塊就不在顯示在首頁中,直到用戶注銷在線狀態(tài)。用戶登錄模塊如圖5.2所示。當?shù)顷懣蛑休斎氲挠脩裘兔艽a在數(shù)據(jù)庫中存在時,利用全局數(shù)組$_SESSION[]保存此次登錄用戶的信息,并提示登錄成功,如圖5.3所示。</p><p>  圖5.2 用戶登錄 圖5.3 提示登錄成功</p><p>  

88、用戶登錄時的進行用戶名及密碼匹配的業(yè)務(wù)操作代碼如下。</p><p><b>  <?php</b></p><p>  require("conn.php");</p><p>  $username =trim($_POST['username']);</p><p>  $

89、pwd = md5(trim($_POST['password']));</p><p>  $sql = "select nicheng from tb_user where username = '".$username."' and pwd = '".$pwd."'";</p><

90、p>  $check_result = mysql_query($sql);</p><p>  if($result = mysql_fetch_array($check_result)){</p><p>  $_SESSION['check'] = 3;</p><p>  $_SESSION['username'] =

91、$username;</p><p>  $_SESSION['nicheng'] = $result[0];</p><p><b>  ?></b></p><p>  <script language="javascript"></p><p>  alert(

92、"登錄成功!");location='index.php';</p><p><b>  </script></b></p><p><b>  <?php </b></p><p><b>  }else{</b></p><

93、p><b>  ?></b></p><p>  <script language="javascript"></p><p>  alert("對不起,你輸入的用戶名或密碼不正確!請重新輸入。");location='index.php';</p><p><

94、;b>  </script></b></p><p><b>  <?php</b></p><p><b>  }</b></p><p>  5.4首頁查看留言的實現(xiàn)</p><p>  (1) 可查看留言的用戶分為兩種,即注冊用戶和非注冊用戶(游客)。<

95、;/p><p>  注冊用戶除了可以查看其他用戶的留言和版主的回復(fù)外,還可以看到自己給版主的悄悄話及版主對此悄悄話的回復(fù),在此非注冊用戶只有瀏覽其他用戶的留言和版主的回復(fù)的權(quán)限。在注冊用戶與非注冊用戶的區(qū)分上用到了變量$_SESSION[‘username’]中保存的用戶名。當首頁被打開時,如果$_SESSION[‘username’]沒被設(shè)置,就可以確定當前的用戶為非注冊用戶,在本頁面中沒有查看悄悄話的權(quán)限;如果$

96、_SESSION[‘username’]不為空,就可以確定當前用戶為注冊用戶。非注冊用戶查看留言的效果如圖5.4所示,注冊用戶查看留言的效果如圖5.5所示。</p><p>  圖5.4 非注冊用戶查看留言效果</p><p>  圖5.5 注冊用戶查看留言效果</p><p>  (2) 在首頁的留言顯示及查看模塊中,采用分頁技術(shù)。</p><

97、p>  確定記錄跨度$row_per_page,即每頁顯示的記錄數(shù),設(shè)置每頁顯示三條留言信息,根據(jù)公式“總記錄數(shù)/跨度”,如果有余數(shù)則進位取整來計算總頁數(shù)$page_count。獲取傳遞的當前頁數(shù)$page_num,通過三目運算符計算判斷第一頁或者最后一頁的位置。最后為SQL語句添加limit子句,計算查詢的起始位置并執(zhí)行SQL語句,將結(jié)果集存儲到數(shù)組中。實現(xiàn)代碼如下。</p><p>  if($_GET

98、){</p><p>  //得到要提取的頁碼</p><p>  $page_num = $_GET['page_num']? $_GET['page_num']: 1;</p><p><b>  }</b></p><p><b>  else{</b><

99、/p><p>  //首次進入時,頁碼為1</p><p>  $page_num = 1;</p><p><b>  }</b></p><p><b>  //得到總記錄數(shù)</b></p><p>  $DB->query($sql);</p><

100、p>  $row_count_sum = $DB->get_rows();</p><p>  //每頁記錄數(shù),可以使用默認值或者直接指定值</p><p>  $row_per_page = 3;</p><p><b>  //總頁數(shù)</b></p><p>  $page_count = ceil($r

101、ow_count_sum/$row_per_page);</p><p>  //判斷是否為第一頁或者最后一頁</p><p>  $is_first = (1 == $page_num) ? 1 : 0;</p><p>  $is_last = ($page_num == $page_count) ? 1 : 0;</p><p><

102、;b>  //查詢起始行位置</b></p><p>  $start_row = ($page_num-1) * $row_per_page;</p><p>  //為SQL語句添加limit子句</p><p>  $sql .= " limit $start_row,$row_per_page";</p>

103、<p><b>  //執(zhí)行查詢</b></p><p>  $DB->query($sql);</p><p>  $res = $DB->get_rows_array();</p><p><b>  //結(jié)果集行數(shù)</b></p><p>  $rows_count=co

104、unt($res);</p><p>  分頁控制鏈接的代碼實現(xiàn)如下。</p><p>  <td align="center" bgcolor="#F9F8EF">『&nbsp;當前第&nbsp;<font color="#AA0066"><?php echo $page_num;?

105、></font>&nbsp;頁/共&nbsp;<font color="#AA0066"><?php echo $page_count;?>&nbsp;</font>頁&nbsp;』&nbsp;&nbsp;每頁『&nbsp;<font color="#AA0066"><

106、?php echo $row_per_page;?></font>&nbsp;』條&nbsp;&nbsp;&nbsp;&nbsp;</p><p><b>  <?php</b></p><p>  if(!$is_first){</p><p><b>  ?>&

107、lt;/b></p><p>  <a href="./index.php?page_num=1">第一頁</a> <a href="./index.php?page_num=<?php echo ($page_num-1) ?>">上一頁</a></p><p><b> 

108、 <?php}</b></p><p>  else{?> 第一頁&nbsp;&nbsp;上一頁<?php}</p><p>  if(!$is_last){</p><p><b>  ?></b></p><p>  <a href="./index

109、.php?page_num=<?php echo ($page_num+1) ?>">下一頁</a> <a href="./index.php?page_num=<?php echo $page_count ?>">最后一頁</a></p><p><b>  <?php</b></p

110、><p><b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p><b>  ?></b></p><p>  下一頁&nbsp;&nbsp;最

111、后一頁</p><p><b>  <?php</b></p><p><b>  }</b></p><p><b>  ?></b></p><p>  &nbsp; <a href="./user_note_read.php?id=-1

112、" target="_blank"> <span class="style2">全部留言</span> </a></td></p><p><b>  </tr></b></p><p><b>  </table></b&g

113、t;</p><p>  5.5留言搜索的實現(xiàn)</p><p>  信息檢索是對已存在與數(shù)據(jù)庫中的數(shù)據(jù)按條件進行篩選瀏覽,是查看歷史信息和確認數(shù)據(jù)操作最為快速、有效的辦法。</p><p>  在留言板中檢索版塊中輸入欲查詢的關(guān)鍵字,對指定條件的留言信息進行模糊查詢,并輸出與查詢條件相匹配的結(jié)果到瀏覽器。本模塊的搜索可根據(jù)標題、內(nèi)容、姓名及時間等任一個關(guān)鍵字進行檢索

114、。留言搜索模塊效果如圖5.6所示。</p><p>  這里用到了like運算符配合通配符進行模糊的查詢,實現(xiàn)留言的檢索功能。</p><p>  $sql = "select note.*,noan.* from tb_note as note left join tb_note_answer as noan on note.note_id = noan.noan_note_i

115、d";</p><p>  $sql.=" where note.note_title like '%".$key_words."%' or note.note_content like '%".$key_words."%' or note.note_time like '%".$key_words.&q

116、uot;%' or note.note_user like '%".$key_words."%'";</p><p>  $DB->query($sql);</p><p>  $note = $DB->get_rows_array($sql);</p><p><b>  圖5.6 留言搜

117、索</b></p><p>  5.6用戶簽寫留言實現(xiàn)</p><p>  本模塊將支持過濾敏感詞、添加留言心情、支持給管理員寫悄悄話,還可以選擇有個性的頭像。同時,方便用戶查看留言后及時簽寫留言信息。簽寫留言模塊效果圖如圖5.7所示。</p><p>  圖5.7 簽寫留言效果圖</p><p>  5.6.1敏感詞過濾<

118、/p><p>  “敏感詞”是指網(wǎng)站管理者為了正常經(jīng)營發(fā)展,減少不必要的紛爭,消除不良影響,而認為設(shè)定的一些交易引起人們歧義思維的詞匯。當系統(tǒng)或管理員發(fā)現(xiàn)帖子里含有特定的敏感詞匯時,該貼會自動被限制發(fā)表或刪除。</p><p>  提交表單信息到數(shù)據(jù)庫處理頁,首先需要對用戶的留言信息進行敏感此過濾。在這里使用正則表達式preg_match()函數(shù)實現(xiàn)。preg_match()函數(shù)用來在字符串中

119、搜索所有與給定的正則表達式匹配的內(nèi)容。當用戶發(fā)表留言信息后,提交留言信息時,將留言信息與存儲在數(shù)組中的敏感詞進行對比,如果含有留言信息中的敏感詞,那么將彈出提示信息,否則留言信息發(fā)布成功。實現(xiàn)敏感詞過濾的關(guān)鍵代碼如下。</p><p>  if($_POST){</p><p>  if (is_file("./filterwords.txt")){//判斷給定文

120、件名是否為一個正常的文件</p><p>  $filter_word = file("./filterwords.txt");//把整個文件讀入一個數(shù)組中</p><p>  $str=$_POST['content'];</p><p>  for($i=0;$i<count($filter_word);$i++){

121、//應(yīng)用For循環(huán)語句對敏感詞進行判</p><p>  $trim_filter_word =trim($filter_word[$i]);</p><p>  if(stristr($str, $trim_filter_word) != FALSE){//判斷傳遞的留言信 </p><p>  echo "<script> alert(&

122、#39;留言信息中包含敏感詞!');history.back(-1);</script>";</p><p><b>  exit;</b></p><p><b>  }}}</b></p><p>  $content =$_POST['content'];</p&g

123、t;<p>  $user_name = $_POST['user_name'];</p><p>  $title = $_POST['title'];</p><p>  $mood=$_POST['mood'];</p><p>  $head = $_POST['head'].&q

124、uot;.gif";</p><p>  $note_flag=$_POST['checkbox'];</p><p>  if($note_flag!=1){$note_flag=0;}</p><p>  $datetime=date("Y-m-d H:i:s");</p><p>  $sq

125、l="insert into tb_note (note_user,note_title,note_content,note_mood,note_time,note_user_pic,note_flag) values('".$user_name."','".$title."','".$content."','&

溫馨提示

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

評論

0/150

提交評論