初學(xué)asp心得體會
初學(xué)asp心得體會
在初學(xué)asp時,這種在web窗體中直接訪問和操作數(shù)據(jù)庫中數(shù)據(jù)的方式是一種低效的資源使用方式,并且有可能產(chǎn)生安全風(fēng)險。通過存儲過程訪問數(shù)據(jù)庫,可以有效地提高數(shù)據(jù)訪問效率和數(shù)據(jù)的安全性做,在此分享心得體會。下面是學(xué)習(xí)啦小編為大家收集整理的初學(xué)asp心得體會,歡迎大家閱讀。
初學(xué)asp心得體會篇1
經(jīng)過兩個多月的學(xué)習(xí)和上課聽講,初步掌握了asp.net動態(tài)網(wǎng)頁制作的一些簡單的知識和基本常識,也能從老師講的基本知識中應(yīng)用一下上課所學(xué)到的知識,感覺asp.net網(wǎng)站建設(shè)和維護(hù)不是很簡單,其中不僅要應(yīng)用各種方面的知識還要對所學(xué)的知識學(xué)會變通使用,雖然會有一些成功的地方,以前學(xué)c++、數(shù)據(jù)庫等一些相關(guān)知識的時候沒好好學(xué),現(xiàn)在想真正做好這個網(wǎng)站就顯得不那么容易了。曾經(jīng)看到網(wǎng)上有這么一句話,一個優(yōu)秀的網(wǎng)絡(luò)程序員不但要了解自己領(lǐng)域的一些專業(yè)技術(shù),而且很多時候還要充當(dāng)半個網(wǎng)絡(luò)工程師,半個美術(shù)設(shè)計師和半個數(shù)據(jù)庫管理員。照這么說來,我單單學(xué)習(xí)asp.net是遠(yuǎn)遠(yuǎn)不夠的,還要學(xué)習(xí)計算機(jī)網(wǎng)絡(luò)、美術(shù)設(shè)計、數(shù)據(jù)庫,我很喜歡有關(guān)計算機(jī)方面的東西,認(rèn)為我們當(dāng)代的生活越來越離不開計算機(jī),并且我也很癡迷計算機(jī)所帶來的強(qiáng)大功能。
它是microsoft .net戰(zhàn)略的核心產(chǎn)品,asp.net憑借它豐富的控件,以及具有革命性的code-behind技術(shù),以及良好的封裝性,無疑成為業(yè)界開發(fā)active server page的一門巨將, asp 是一項微軟公司的技術(shù),是一種使嵌入網(wǎng)頁中的腳本可由因特網(wǎng)服務(wù)器執(zhí)行的服務(wù)器
端腳本技術(shù)。 指 active server pages(動態(tài)服務(wù)器頁面) ,運(yùn)行于 iis 之中的程序 。asp.net 是 asp(微軟動態(tài)服務(wù)器網(wǎng)頁技術(shù))的最新版本。執(zhí)行效率大幅提高:asp.net構(gòu)架是可以用microsoft(r)公司最新的產(chǎn)品 visual studio.net開發(fā)環(huán)境進(jìn)行開發(fā),wysiwyg(what yousee is what you get所見即為所得)的編輯。簡單性和易學(xué)性
高效可管理性
asp.net使用一種字符基礎(chǔ)的,分級的配置系統(tǒng),使你服務(wù)器環(huán)境和應(yīng)用程序的設(shè)置更加簡單。因為配置信息都保存在簡單文本中,新的設(shè)置有可能都不需要啟動本地的管理員工具就可以實現(xiàn)。這種被稱為"zerolocal administration"的哲學(xué)觀念使asp.net的基于應(yīng)用的開發(fā)更加具體,和快捷。一個asp.net的應(yīng)用程序在一臺服務(wù)器系統(tǒng)的安裝只需要簡單的拷貝一些必須得文件,不需要系統(tǒng)的重新啟動,一切就是這么簡單。多處理器環(huán)境的可靠性 asp.net已經(jīng)被刻意設(shè)計成為一種可以用于多處理器的開發(fā)工具,它在多處理器的環(huán)境下用特殊的無縫鏈接技術(shù),將很大的提高運(yùn)行速度。即使你現(xiàn)在的asp.net應(yīng)用軟件是為一個處理器開發(fā)的,將來多處理器運(yùn)行時不需要任何改變都能提高他們的效能,但現(xiàn)在的asp確做不到這一點。自定義性和可擴(kuò)展性 asp.net設(shè)計時考慮了讓網(wǎng)站開發(fā)人員可以在自己的代碼中自己定義"plug-in"的模塊。這與原來的包含關(guān)系不同,asp.net可以加入自己定義的如何組件。網(wǎng)站程序的開發(fā)從來沒有這么簡單過。
安全性基于windows認(rèn)證技術(shù)和每應(yīng)用程序配置,你可以確性你的原程序時絕對安全的。 asp.net 的語法在很大程度上與 asp 兼容,同時它還提供一種新的編程模型和結(jié)構(gòu),可生成伸縮性和穩(wěn)定性更好的應(yīng)用程序,并提供更好的安全保護(hù)??梢酝ㄟ^在現(xiàn)有 asp 應(yīng)用程序中逐漸添加 asp.net 功能,隨時增強(qiáng) asp 應(yīng)用程序的功能。 asp.net 是一個已編譯的、基于 .net 的環(huán)境,把基于通用語言的程序在服務(wù)器上運(yùn)行。將程序在服務(wù)器端首次運(yùn)行時進(jìn)行編譯,比asp即時解釋程序速度上要快很多.而且是可以用任何與 .net 兼容的語言序。另外,任何 asp.net 應(yīng)用程序都可以使用整個 .net framework。開發(fā)人員可以方便地獲得這些技術(shù)的優(yōu)點,其中包括托管的公共語言運(yùn)行庫環(huán)境、類型安全、繼承等等。 asp.net 可以無縫地與 wysiwyg html 編輯器和其他編程工具(包括 microsoft visual studio .net)一起工作。這不僅使得 web 開發(fā)更加方便,而且還能提供這些工具必須提供的所有優(yōu)點,包括開發(fā)人員可以用來將服務(wù)器控件拖放到 web 頁的gui 和完全集成的調(diào)試支持。
當(dāng)創(chuàng)建 asp.net 應(yīng)用程序時,開發(fā)人員可以使用 web 窗體或 web,或以他們認(rèn)為合適的任何方式進(jìn)行組合。每個功能都能得到同一結(jié)構(gòu)的支持,使您能夠使用身份驗證方案,緩存經(jīng)常使用的數(shù)據(jù),或者對應(yīng)用程序的配置進(jìn)行自定義. 如果你從來沒有開發(fā)過網(wǎng)站程序,那么這不適合你,你應(yīng)該至少掌握一些html和簡單的web開發(fā)術(shù)語(不過我相信如果有興趣的話是可以很快的掌握的)。你不需要先前的asp開發(fā)經(jīng)驗(當(dāng)然有經(jīng)驗更好),但是你必須了解交互式web程序開發(fā)的概念,包含窗體,腳本,和數(shù)據(jù)接口的概念,如果你具備了這些條件的話,那么你就可以在asp.net的世界開始展翅高飛了。
首先我們學(xué)習(xí)了怎么設(shè)計主頁,一個好的主頁可以給瀏覽者一個耳目一新的感覺,所以網(wǎng)站主頁的布局就顯得格外重要了,好的布局加上親切的言語,以及強(qiáng)大的功能,都會是瀏覽者感到無比的親切。這次我跟劉昕做的是樂糕網(wǎng),一個粉紅色的布局顯出溫馨的格調(diào),其次我們添加了用戶注冊界面,同時應(yīng)用了模板頁,模板頁嵌套在注冊頁面上,同時與主頁的注冊按鈕相連接,在主頁引用了css樣式,使得格局更加清晰。之后我們做了在線投票頁面,同樣引用了模板頁,同時學(xué)會了使用cookie,session的使用。做好這些功能之后,我們開始用到了數(shù)據(jù)庫,要實現(xiàn)用戶的存儲和調(diào)用,以及商品信息的錄入,同時對商品id進(jìn)行數(shù)據(jù)綁定,之后我們實現(xiàn)了購物車功能,使用 datalist控件實現(xiàn)了對后臺代碼文件中綁定其數(shù)據(jù)源,asp,net3.5提供的datalist控件使用模板顯示內(nèi)容,他允許每一行顯示多條記錄??梢允褂胔tml表對應(yīng)模板項的呈現(xiàn)方式進(jìn)行布局,從而控制各個單元格的順序、方向和列數(shù)。在這之后我們又做了留言板,通過ado.net調(diào)用存儲過程,做到了留言板功能的實現(xiàn),。前面所學(xué)到的數(shù)據(jù)訪問都是web應(yīng)用程序直接訪問數(shù)據(jù)庫。這種在web窗體中直接訪問和操作數(shù)據(jù)庫中數(shù)據(jù)的方式是一種低效的資源使用方式,并且有可能產(chǎn)生安全風(fēng)險。通過存儲過程訪問數(shù)據(jù)庫,可以有效地提高數(shù)據(jù)訪問效率和數(shù)據(jù)的安全性。
可以在執(zhí)行復(fù)雜任務(wù)時減少窗體的編碼量,降低對網(wǎng)絡(luò)寬帶的需求;通過只允許可信賴的本地存儲過程直接訪問數(shù)據(jù)庫,可以保護(hù)數(shù)據(jù)庫的安全。同時我們用到了一個容器控件repeater,當(dāng)運(yùn)行頁面時,repeater將綁定數(shù)據(jù)源中的數(shù)據(jù),并按照模板的要求將數(shù)據(jù)在界面上呈現(xiàn)出來。正是由于repeater控件沒有默認(rèn)的外觀,所以進(jìn)行界面設(shè)計的時候會感到不太直觀。但repeater控件非常靈活,可以通過對模板的靈活使用,創(chuàng)建多種不同形式的列表,包括以特定分隔符的列表,或者xml格式的列表,同時它還能夠非常精確地對界面元素進(jìn)行定位。除此之外我們還添加了網(wǎng)絡(luò)在線投票功能,網(wǎng)絡(luò)在線投票是網(wǎng)絡(luò)用戶的興趣、價值取向以及熱點關(guān)注等信息的關(guān)注程度的一種體現(xiàn),實現(xiàn)了在線投票功能,為了更為直觀的顯示和查看投票結(jié)果,將投票結(jié)果圖形化是一種較好的手段。所以我們引用了一個類graphics, graphics類是gdi+圖形編程中的核心類。他封裝了gdi+界面的繪圖方法以及圖形顯示設(shè)備,極大地的簡化了開發(fā)人員的圖形編程工程工作。通過graphics類的屬性可以獲取graphics對象的分辨率,并能夠為graphics對象進(jìn)行裁剪區(qū)域的選擇和判斷,而頁面中圖形的繪制則都是通過graphics類的實例方法實現(xiàn),同時引用了web服務(wù)器控件image。image控件同img標(biāo)簽一樣,其主要作用是在web頁面中顯現(xiàn)圖片信息,其主要屬性為imageurl,用于設(shè)置需要顯示的圖片的url地址。盡管asp.net提供的image控件可以快速地載入圖形,但卻并不支持click事件。而且gdi+除了可以繪制圖形和文字外,還可以繪制或編輯已有圖片,為圖片添加水印或裁剪圖片等操作。
在實際的web應(yīng)用開發(fā)中,開發(fā)人員為了防止非法用戶惡意批量注冊或者惡意程序暴力破解密碼等操作,我們相應(yīng)的做了圖形驗證碼功能,在用戶身份驗證時都會采用驗證碼技術(shù)。驗證碼技術(shù)可以有效防止某些特定注冊用戶采用惡意程序和暴力破解方式對網(wǎng)站進(jìn)行不斷的登錄嘗試,為此我們引用了random類,隨即數(shù)在計算機(jī)應(yīng)用程序設(shè)計,尤其是在實踐環(huán)境模擬和測試等領(lǐng)域得到了非常廣泛的應(yīng)用。random類是一個偽隨即數(shù)生成器,能夠產(chǎn)生滿足一定隨即性系統(tǒng)要求的數(shù)字序列。既然是偽隨機(jī)數(shù)生成器,產(chǎn)生的數(shù)字就不是絕對的隨即數(shù),而是通過一定的算法產(chǎn)生的偽隨機(jī)數(shù)。初始化一個隨機(jī)數(shù)發(fā)生器有兩種方法:第一種是不指定隨即種子,系統(tǒng)自動選取當(dāng)前時間作為隨機(jī)種子,代碼如下:random rand=new random();第二種方法是指定一個int型參數(shù)作為隨即種子,認(rèn)
識到了網(wǎng)站的真正的結(jié)構(gòu),最終才對bs結(jié)構(gòu)的網(wǎng)站程序有了進(jìn)一步的認(rèn)識。同時,對sql大型數(shù)據(jù)庫的認(rèn)識才有了質(zhì)的改變。最后我們做了網(wǎng)絡(luò)在線人數(shù)統(tǒng)計,完成了對樂購網(wǎng)網(wǎng)站的制作。
在這短短的幾個月中,我知道在程序設(shè)計的時候,不要太在意程序是否最簡潔靈活,對于一般開發(fā)者而言,程序規(guī)范化和可讀性可能比追求程序的靈活性更加重要。在互聯(lián)網(wǎng)資源越來越豐富的情況下,我們可以參考一些規(guī)范的程序源代碼來學(xué)習(xí)。同時我也知道,想要學(xué)好這門課程,所要具備很多條件,首先打代碼要規(guī)范,要做注釋,這樣回頭來看程序時可以很快的看懂,一方面可以練習(xí)自己的邏輯表達(dá)能力,對以后遇到難以實現(xiàn)的功能也可以很好的表達(dá)出來向別人請教,而且出去從事編程工作的話,代碼的規(guī)范是相當(dāng)重要的。還有一點要學(xué)會總結(jié),把自己做的程序用到的知識點列出來就可以很好的總結(jié)自己的知識點。當(dāng)形成知識體系,對知識的理解就會更上一層樓。
初學(xué)asp心得體會篇2
ASP內(nèi)置對象response
Response的屬性
.buffer (表明頁輸出是否被緩沖)
使用格式
Response.buffer=true/false
注:很多方法使用時對BUFFER屬性有要求,對其設(shè)置最好寫在ASP文件第一行。
.ContentType (指定HTTP輸出內(nèi)容類型)
使用格式
Response.ContentType="內(nèi)容類型"
.BinaryWrite (不經(jīng)過任何轉(zhuǎn)換,將指定的信息輸出,它主要輸出非字符信息)
使用格式
Response.BinaryWrite 二進(jìn)制數(shù)據(jù)
Clear/End/Flush與Buffer屬性的依賴關(guān)系
{
.Clear (把緩沖區(qū)內(nèi)容清空)
.End (停止執(zhí)行后面的代碼,緩沖區(qū)內(nèi)容仍然有效)
.Flush (緩沖區(qū)中編譯完成的數(shù)據(jù)先發(fā)送到客戶端)
}
.Redirect (跳轉(zhuǎn)網(wǎng)頁,必須將Buffer的屬性設(shè)置為TRUE)
使用格式
Response.Redirect 網(wǎng)址
Request對象Cookies集合用來取得用戶的相關(guān)信息
Response對象Cookies集合負(fù)責(zé)將數(shù)據(jù)設(shè)置到瀏覽器
寫入Cookies到用戶瀏覽器
response.Cookies("Cookies名")="Cookies值"
讀取Cookies
request.Cookies("Cookies名")
另類的Cookies
response.Cookies("Cookies名")("元素")
另類的Cookies的讀取
request.Cookies("Cookies名")("元素")
.expires (設(shè)置Cookies的過期時間)
使用格式
respones.Cookies("Cookies名").expires="過期的時間 (例:2006-7-17 7:17)"分享:
初學(xué)asp心得體會篇3
一、準(zhǔn)備工作
首先,學(xué)習(xí)asp要有些基本的編程知識.最好先學(xué)過點vb java最好因為asp不是一門編程語言而是一個web編程框架.他是利用腳本(vbscript javascript)語言做為編程語言的.如果你不會他們那么至少得會點c.c也不會的話建議你先學(xué)下c,雖然并不是一定要先學(xué)過編程語言,但是學(xué)他對這個的學(xué)習(xí)是有莫大的好處的.在asp.net中,整張web頁是放在一張大表單里面的。如:
網(wǎng)頁的具體內(nèi)容??
在這個表單內(nèi)可能放置了很多html控件如按鈕、下拉菜單、文本框等。asp.net提供了一些服務(wù)器端web控件。在服務(wù)器上執(zhí)行的時候,通過一定的條件,web窗體將這些服務(wù)器web控件轉(zhuǎn)換為普通的html控件。比如一個按鈕:
經(jīng)過轉(zhuǎn)換后就變成了:
在asp.net中,一個web窗體被看成了一個對象。它的數(shù)據(jù)成員就是那些web控件和你自己定義的變量,它的函數(shù)成員就是那些用來響應(yīng)客戶端操作的函數(shù),當(dāng)然還有你自己定義的函數(shù)。我大致講一下用戶請求一張web頁的時候發(fā)生了一些什么事件:
首先,用戶第一次請求頁面時,先執(zhí)行web頁的page_init過程,在這里通常對組件進(jìn)行初始化。然后執(zhí)行page_load過程,在這里,我們可以做一些初始化的工作。比如:設(shè)定標(biāo)簽控件的文本為:“初始”。然后,由于用戶是第一次請求頁面,所以沒有什么其他事件發(fā)生。程序控制轉(zhuǎn)為解釋執(zhí)行html代碼頁中的服務(wù)器代碼。在html中,有一個這就是我們的標(biāo)簽控件。因為我們在page_load過程中對標(biāo)簽的文本賦值了,所以現(xiàn)在程序在將轉(zhuǎn)換為初始。而按鈕的轉(zhuǎn)換就類似于上面我已經(jīng)說過內(nèi)容。經(jīng)過這些轉(zhuǎn)換以后,html頁內(nèi)的代碼變成了標(biāo)準(zhǔn)的代碼。然后,這些代碼被用戶瀏覽器得到了。經(jīng)過解析后,用戶就可以看到一個“初始”和一個按鈕。
現(xiàn)在,用戶對著按鈕點擊了一下。于是,表單就提交了。(提交的細(xì)節(jié),我下面再說)通過提交的表單,服務(wù)器得知這是用戶點擊了按鈕控件。并且這是用戶第二次請求該頁面了。于是,程序又執(zhí)行page_init過程、page_load過程。這時,因為用戶點擊了按鈕控件,則程序開始執(zhí)行另一個函數(shù),這個函數(shù)是用來專門處理用戶點擊了按鈕控件這個事件的。在這里,我們將標(biāo)簽控件的文本設(shè)置為:“點擊”。然后程序控制又轉(zhuǎn)到html頁。跟上面第一次請求時一樣。于是用戶在客戶端通過瀏覽器就可以看到一個“點擊”和一個按鈕了。
.net是通過隱藏控件來傳遞客戶端信息的,例如產(chǎn)生事件的控件的名字。然后,提交表單。這樣,服務(wù)器端就可以根據(jù)隱藏控件來確定產(chǎn)生事件的控件的名字,并產(chǎn)生服務(wù)器事件,進(jìn)而對該事件進(jìn)行處理。
對于一個熟練的程序員來說,他也不可能完全記住每個語言的各項細(xì)節(jié).再簡單的語言也有很復(fù)雜的細(xì)節(jié),所以幫助文件是必須的.在一次又一次的查閱中你會發(fā)現(xiàn)自己查閱的次數(shù)越來越少了.如果你基本上不查閱了,那么你已經(jīng)基本上掌握這么語言了.(為什么說基本上,那是因為一門語言不是只有語法,還有其他的,比如編程思想,特性等)我列出的這些都是必須的,當(dāng)然還可以有些別的比如xml ajax技術(shù)等
運(yùn)行環(huán)境
在這里推薦iis畢竟asp是人家微軟的技術(shù).人家又那么牛,別人很難做的比他好啊!aspstudio很容易出錯,不怎么好,不推薦做大型項目.但是個人做點小東西的很方便很好,不過他好象不支持類的功能(也許是我沒找到支持它的版本,有請大蝦指出).net沒用過有請大家討論下!
數(shù)據(jù)庫
建議初學(xué)的話用access因為起功能簡單.也容易上手.但是最終你還是要會大型數(shù)據(jù)庫的,現(xiàn)在對網(wǎng)絡(luò)程序員的招聘一般要回oracle sqlserver mysql.
二、開始學(xué)習(xí)
學(xué)習(xí)asp首先得開始學(xué)習(xí)靜態(tài)頁面開始,如果你有這方面的知識那么可以省略。
靜態(tài)頁面
靜態(tài)頁面就是純html語言加客戶端javascript的頁面。所以你可一先學(xué)習(xí)下html語言,但是如果不是學(xué)過面向?qū)ο缶幊痰脑?,建議你先不要看javascript。先就學(xué)點 html語言,不要太深就學(xué)習(xí)個基本的表格,字體樣式,基本的結(jié)構(gòu)就可以了。然后再學(xué)會用網(wǎng)頁三劍客。特別是要學(xué)好用dreamvear.
頁面大小:一個頁面的大小一般是寬度778像素或者是1024像素,但是大多數(shù)是用的778因為現(xiàn)在還有很多顯示器很差設(shè)置的是778像素。這樣能更多的支持。當(dāng)然你可以設(shè)置為百分比這樣就不會為這個而煩惱了!比如54的頁面就是設(shè)置的百分比(一般的論壇都是)。logo和banner:一般logo和banner也是有固定尺寸的logo一般88×31而banner一般是和網(wǎng)頁的寬度差不多可以是778和1024高度最好不要超過120
網(wǎng)頁標(biāo)題:好多人最開始學(xué)習(xí)的時候沒怎么注意過結(jié)果他編的網(wǎng)頁都是無標(biāo)題文檔。記住在中間加個標(biāo)題。
網(wǎng)頁關(guān)鍵字:網(wǎng)頁的關(guān)鍵字是搜索工具檢索網(wǎng)頁的重要依據(jù),有效的關(guān)鍵字對于提高網(wǎng)站排名及人氣很有用處。
版權(quán)信息:一個網(wǎng)頁一定得有個版權(quán)信息,這是專業(yè)與非專業(yè)的區(qū)別。當(dāng)然加上一些聯(lián)系方式比如郵件地址等,方便別人的聯(lián)系。如果你的網(wǎng)站有什么問題,網(wǎng)上還是有很多熱心人通知你的。
文件名: 建議大家才開始學(xué)習(xí)的時候就養(yǎng)成良好的習(xí)慣。用英文命名,同時最好能表達(dá)你的文件的主要內(nèi)容,可以是英文單詞,或者是拼音,當(dāng)然英文是最好的。不是特殊要求請不要用特殊字符,比如#等
javascript:javascript開始的時候可以不用學(xué)習(xí),網(wǎng)上的這些代碼很多很詳細(xì),連怎么樣運(yùn)用都寫的很清楚??梢灾苯诱襾磉\(yùn)用。
1.另外為了防止代碼亂碼,所以要有句如上面的.因為中文編碼都是gb2312不加這句很榮譽(yù)出錯出現(xiàn)亂碼
2。開始學(xué)習(xí)的時候你可能沒注意過代碼的排版。html你可以用dm看,但是當(dāng)你開始編輯動態(tài)頁面的時候就要注意。一個好的排版能夠讓別人讀懂你的代碼(這個很關(guān)鍵,你進(jìn)公司工作,不可能一個人開發(fā)整個系統(tǒng))。關(guān)鍵是做好縮進(jìn)html代碼如是,asp代碼也是。
3。開始學(xué)習(xí)的時候不要貪多爭取先弄懂一的對象比如adodb,然后在看別的。其實所有的東西基本都是一個模板。主要是理解,絕不要強(qiáng)求記憶。記憶是等你做多之后自然的事情。不過最基本的對象開始你得弄懂,比如request response要學(xué)會運(yùn)用他們。
4。開始學(xué)習(xí)的時候要弄清楚一些基本的技術(shù)。包括分頁技術(shù);數(shù)據(jù)庫的連接,數(shù)據(jù)的查詢,刪除;數(shù)據(jù)庫的基本操作,表的建立,刪除。
三、編程實踐
編程只看教程,只看書是不行的。需要你實際操作,才知道一些細(xì)節(jié)的問題.
開始編的話可以學(xué)習(xí)編寫一些小的模塊.比如新聞顯示,或折一個簡單的留言本.練習(xí)下.然后做個簡單的整站試下.
編程的時候要注意代碼盡量思路清晰.要有高的擴(kuò)展性,便宜以后擴(kuò)展.所以盡量做成函數(shù)和過程再在頁面里面調(diào)用.
同時這里也有些需要提醒大家注意的地方
1.前期設(shè)計工作
設(shè)計一個網(wǎng)站是其實主要的工作不是在后面的編程,而關(guān)鍵成功的因素是在前期的歸劃.前期要弄明白你的需求是什么.要實現(xiàn)什么功能.劃分好每個功能模塊.為每個功能模
塊,劃分好好實現(xiàn)的各個功能函數(shù).最好有一個清晰的計劃書.如果著一切你都事先做的橫好那么后面編程是很簡單的事情.一切水道渠成.
2.數(shù)據(jù)庫設(shè)計
數(shù)據(jù)庫設(shè)計也是非常重要的,一個好的數(shù)據(jù)庫設(shè)計就為一個漂亮的開始.
數(shù)據(jù)庫盡量簡單,不要建立太多的表.一個表要盡量容入多的數(shù)據(jù).但是這個是在一個原則的條件下,數(shù)據(jù)庫設(shè)計的要清晰.最好一個對象建立一個表.而對于某個對象起屬性少的情況下,就不要建立一表.
比如我門常用的電子郵件,如過你不是做郵件服務(wù)器的話就沒的必要建立電子郵件的表,你只要在用戶的表里面建立個email字段就可以了.
另外要特別注意數(shù)據(jù)庫的速度,網(wǎng)絡(luò)一切速度第一.所以你最好要為每張表建立一個int類型的id字段我們查詢的時候就查詢id,由于是數(shù)字,比字符的查詢的速度快(在大量數(shù)據(jù)的情況下很明顯)當(dāng)然這就以為著你必須檢查,或者設(shè)置id字段的值不能重復(fù).當(dāng)然還有的就是你得有個習(xí)慣就是所有的字段都是用英文表示(有點廢話,但是也許有寫人不知道),也上為了提高速度,同時便宜兼容別的不支持漢語的數(shù)據(jù)庫.
3.數(shù)據(jù)庫的查詢等
數(shù)據(jù)庫的操作很重要,他很影響整個程序的速度.注意:一般一個網(wǎng)站的速度限制住要是在網(wǎng)絡(luò)帶寬,和內(nèi)存的大小.而數(shù)據(jù)庫是耗內(nèi)存的大戶,同時他的訪問速度也限制整個網(wǎng)頁的速度(對于小型網(wǎng)站這個是主要的限制因素).
所以數(shù)據(jù)庫的操作很重要.我們在做數(shù)據(jù)庫操作的時候要記得盡量提高查詢速度.首先,要編寫盡量簡單的查詢語句,不要一個查詢語句里面做很多圈套,少用或盡量不用聯(lián)合查詢.
盡量在搜索的時候用id字段查詢,少查詢字符,提高檢索速度.
其次,對于數(shù)據(jù)庫的資源.當(dāng)申請了連接用完就釋放.于最早的時間釋放資源.然后如果數(shù)據(jù)庫里面的記錄特別多的話,那么就最好做一些優(yōu)化我們在查詢的時候只查詢前面1000記錄避免暫時無用的數(shù)據(jù)占用資源.同時也可以用asp自代的分頁功能.adoob對象有這個功能.
再次,對于復(fù)雜的事物處理我們可以用視圖和存儲過程,事實證明運(yùn)用試圖存儲過程能顯著提高速度.當(dāng)然建立必要的索引也是可以的.要在這些方面做好取舍.不過前提是你所用的數(shù)據(jù)庫都支持.
最后,我們可以把經(jīng)常用的業(yè)務(wù)查詢放入內(nèi)存.來優(yōu)化速度.這樣當(dāng)每次尋要用的時候就可以直接去內(nèi)存尋找,避免每次都查詢數(shù)據(jù)庫.
4.asp編程
首先,我們?nèi)绻砰_始編程的的話,不要求什么新技術(shù).盡量采用簡單的技術(shù).其實一個程序如果設(shè)計的思想很好很漂亮,那么我們就沒必要關(guān)心他是用什么技術(shù)實現(xiàn)的哪怕是最初級的技術(shù).一樣
是好程序,只要它能達(dá)到最開始的要求就是.而且對于我們才開始學(xué)習(xí)的人,如果一就研究這些復(fù)雜的東西是困難的,也沒的必要啊.等你基本是上很熟悉asp編程了.你可以去閱讀技術(shù)文檔.再去學(xué)習(xí).
其次,我們要照顧一些安全的需要.
1.檢測下sql語句編寫安全的sql語句.
比如這樣的語句就不怎么好:sql="select * from table1 where name="&rename傳過來的可能代有'號可以夠造一個查詢被注射.
可以這么寫sql="select * from table1 where name='"&rename&"'"
2.時刻記得檢測傳遞過來的request對象,加一句replace(cint(request("")),"'","")
可以起到一定的防范作用.
3.對于權(quán)限的檢測有些人只用cookies驗證,這是不行的現(xiàn)在有工具可以自己構(gòu)造這個.因為cookies是放在客戶端的,很容易被黑課利用.對于次我們可以采用cookies 加session驗證的辦法.
4.另外記得數(shù)據(jù)庫的安全,要做下防下載的處理.可以用幾個變態(tài)的數(shù)據(jù)庫名,同時在數(shù)據(jù)庫里面建立個防止下載的表.防止被暴庫.同時帳號密碼最好加下密采用md 5加密一般不好被破解.
5.對于用戶的登陸頁面的驗證.我們在查詢的時候最好最好加下面的語句
code:
'前面為查詢
if not rs.eof then
if rs("username")=md5(username) and rs("userpass")=md5(userpass) thensession("user")=true
response.redirect"轉(zhuǎn)入成功頁面"
else
response.redirect"轉(zhuǎn)入錯誤頁面"
end if
end if
同時我們在登陸的地方最好要有的驗證碼驗證,或者記錄錯誤登陸次數(shù).限制同一ip多次錯誤的登陸.防止被暴力破解.
6.后臺編輯器我門盡量不要采用html編碼,可以采用ubb代碼,防止被嵌入木馬等.存儲如數(shù)據(jù)庫的時候要采用字符過濾.過濾掉一些危險的單詞,如 delete in to content 等最后要說的是編譯運(yùn)行.
你寫的代碼不可能是完全正確的.需要通過服務(wù)器的檢測才行.但是一般一經(jīng)檢測都有那么點問題.這時候就需要調(diào)試.我推薦大家采用aspstudio因為他可以設(shè)置斷點.方便找錯及修改.不過他的技術(shù)可能不是很成熟有時候出錯.所以你有時候還是得用iis.有是在本地運(yùn)行不了的程序,在服務(wù)器上卻可以.所一你最好有個個人的動態(tài)空間.方便測試.另外說下的是,找錯誤.一般是出的小錯誤.比如編碼格式,或者一個if沒結(jié)束.這個以為就是邏輯錯誤
在眾多的if語句中出錯誤.大家向這個方面去找.一般不是什么大問題.
四、總結(jié)
asp是容易上手,而且速度也很好,不用編譯為可執(zhí)行程序,所以他才這么流行.但是現(xiàn)在看來我感覺他的前途不大了.因為它有太多的毛病.首先這個東西似乎特別不怎么安全.我看見的網(wǎng)站入侵大多數(shù)是asp的.其次它也不適宜特別大的項目.作為小中型運(yùn)用還可以.做為大型.他一是很不好做好邏輯與業(yè)務(wù)分離.程序用到東西太多,代碼再怎么注意清晰的編寫都感覺很亂.程序的偶合程度太強(qiáng).不便于以后改進(jìn)更新.十分不便于多人開發(fā).然后相對于jsp他不能跨平臺.沒有其有著從小型到大型的web運(yùn)用的成熟的解決方案強(qiáng)大語言支持.同時不能向php一樣開源.而微軟現(xiàn)在又關(guān)注的是.net平臺.
初學(xué)asp心得體會相關(guān)文章: