电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

ASP編碼必備的8條原則

瀏覽:262日期:2022-06-05 11:49:44

ASP是Active Server Page的縮寫,意為“動態(tài)服務(wù)器頁面”。ASP是微軟公司開發(fā)的代替CGI腳本程序的一種應(yīng)用,它可以與數(shù)據(jù)庫和其它程序進(jìn)行交互,是一種簡單、方便的編程工具。在這里僅就代碼優(yōu)化進(jìn)行一些簡單討論。

1、聲明VBScript變量

在ASP中,對vbscript提供了強勁的支持,能夠無縫集成vbscript的函數(shù)、方法,這樣給擴(kuò)展ASP的現(xiàn)有功能提供了很大便利。由于ASP中已經(jīng)模糊了變量類型的概念,所以,在進(jìn)行ASP與vbscript交互的過程中,很多程序員也慣于不聲明vbscript的變量,這樣加重了服務(wù)器的解析負(fù)擔(dān),進(jìn)而影響服務(wù)器的響應(yīng)請求速度。

鑒于此,我們可以象在VB中強制用戶進(jìn)行變量聲明一樣在vbscript中強制用戶進(jìn)行變量聲明。實現(xiàn)方法是在ASP程序行首放置<% option explicit%>。

2、對URL地址進(jìn)行編碼

在我們使用asp動態(tài)生成一個帶參數(shù)URL地址并進(jìn)行跳轉(zhuǎn)時,在IE中解析很正常,但在NetScrape瀏覽時卻有錯誤如下:

HTTP Error 400  
400 Bad Request  
Due to malformed syntax, the request could not be understood by the server.  
The client should not repeat the request without modifications. 

解決方法是對生成的URL參數(shù)使用ASP內(nèi)置server對象的URLencode方法進(jìn)行URL編碼,例子如下:

<%  
URL="xur.asp"  
var1="username=" & server.URLencode("xur")  
var2="&company=" & server.URLencode("xurstudio")  
var3="&phone=" & server.URLencode("021-53854336-186")  
response.redirect URL & "?" & var1 & var2 & var3  
%> 

3、清空對象

當(dāng)使用完對象后,首先使用Close方法來釋放對象所占用的系統(tǒng)資源;然后設(shè)置對象值為“nothing”釋放對象占用內(nèi)存。當(dāng)年,我就是在一張頁面上創(chuàng)建了百余個沒有清空對象的記錄集而崩潰了我的IIS 。下面的代碼使用數(shù)據(jù)庫內(nèi)容建立一個下拉列表。代碼示例如下:

<% myDSN="DSN=xur;uid=xur;pwd=xur"  
mySQL="select * from authors where AU_ID<100"  
set conntemp=server.createobject("adodb.connection")  
conntemp.open myDSN  
set rstemp=conntemp.execute(mySQL)  
if rstemp.eof then  
response.write "數(shù)據(jù)庫為空"  
response.write mySQL  
conntemp.close  
set conntemp=nothing  
response.end  
 end if%>  
<%do until rstemp.eof %>  
<%  
rstemp.movenext  
loop  
rstemp.close  
set rstemp=nothing  
conntemp.close  
set conntemp=nothing  
%> 

4、使用字符串建立SQL查詢

使用字符串來建立查詢并不能加快服務(wù)器的解析速度,相反,它還會增加服務(wù)器的解析時間。但在這里仍然推薦使用字符串代替簡單的查詢語句來進(jìn)行查詢。這樣做的好處是,可以迅速發(fā)現(xiàn)程序問題所在,從而便利高效地生成程序。示例如下:

<%mySQL= ""select * "  
mySQL= mySQL & "from publishers"  
mySQL= mySQL & "where state="NY""  
response.write mySQL  
set rstemp=conntemp.execute(mySQL)  
rstemp.close  
set rstemp=nothing  
%> 

5、使用case進(jìn)行條件選擇

在進(jìn)行條件選擇的時候,盡量使用case語句,避免使用if語句。使用case語句,可以使程序流程化,執(zhí)行起來也比if語句來的快。示例如下:

<%  
FOR i = 1 TO 1000  
 n = i  
 Response.Write AddSuffix(n) & "<br>"  
NEXT  
%>  
<%  
Function AddSuffix(num)  
numpart = RIGHT(num,1)  
Select CASE numpart  
CASE "1"  
IF InStr(num,"11") THEN  
num = num & "th"  
ELSE  
num = num & "st"  
END IF  
CASE "2"  
IF InStr(num,"12") THEN  
num = num & "th"  
ELSE  
num = num & "nd"  
END IF  
CASE "3"  
IF InStr(num,"13") THEN  
num = num & "th"  
ELSE  
num = num & "rd"  
END IF  
CASE "4"  
num = num & "th"  
CASE ELSE  
num = num & "th"  
END Select  
AddSuffix = num  
END FUNCTION  
%> 

6、使用adovbs.inc文件中定義的常量打開記錄集

打開記錄集時,可以定義記錄集打開的游標(biāo)類型和鎖定類型。

在adovbs.inc文件中定義了一些常量來定義這些類型。adovbs.inc文件保存在\inetpub\iissamples\IISamples目錄下面。下面列舉幾個常用的游標(biāo)類型和鎖定類型。

游標(biāo)類型:

  • adOpenFowardOnly游標(biāo)只能向前;
  • adOpenKeyset游標(biāo)可向前或者向后,如一用戶添加記錄,新記錄不會出現(xiàn)在記錄集中;
  • adOpenDynamic游標(biāo)動態(tài)隨意;
  • adOpenStatic記錄集不對其他用戶造成的記錄修改有所反映。

鎖定類型:

  • adLockReadOney不能修改記錄集中的記錄;
  • adLockPessimistic在編輯一條記錄時鎖定它;
  • adLockOptimstic調(diào)用記錄集Update方法時才鎖定記錄;
  • adLockBatchOpeimstic記錄只能成批更新。
<!--#INCLUDE VIRTUAL="/ADOVBS.INC" -->  
<%  
connectme="DSN=xur;uid=xur;pwd=xur"  
sqltemp="select * from publishers where name="xur""  
set rstemp=Server.CreateObject("adodb.Recordset")  
rstemp.open sqltemp, connectme, adOpenStatic,adLockOptimstic  
response.write rstemp.recordcount & " records in<br>" & sqltemp  
rstemp.close  
set rstemp=nothing  
%> 

7、避免在使用global.asa文件中進(jìn)行對象定義

由于global.asa文件中的內(nèi)容可以為站點內(nèi)所有文件引用,無疑,在global.asa文件中進(jìn)行對象定義可以省去很多重復(fù)工作。

比如在global.asa中的application_onstart函數(shù)中進(jìn)行如下定義:

<%SUB application_onstart  
set application("theCONN")=server.createobject("adodb.connection")  
END SUB %>; 

這樣就可以在站點任何代碼中做類似引用:

<%  
mySQL="select * from publishers where state="xur"  
set rstemp=application("theconn").execute(mySQL)  
%> 

同樣地,可以在session_onstart函數(shù)中創(chuàng)建記錄集對象

<%SUB session_onstart  
set session("rstemp")=server.createobject("adodb.recordset")  
END SUB %> 

然后在站點也面中進(jìn)行如下引用:

<%  
mySQL="select * from publishers where state="xur"  
set session("rstemp")=conntemp.execute(mySQL)  
%> 

但這樣做的同時也有很大的負(fù)面影響,由于Application和session變量都只有在關(guān)閉網(wǎng)站的時候才釋放占用的資源,所以session參數(shù)會浪費大量不必要內(nèi)存,而且此時application變量成為服務(wù)器性能的瓶頸。

解決方法:

建立定義對象asp頁面,在需要進(jìn)行調(diào)用這些對象的頁面上,引入這張asp頁面。假設(shè)定義對象的asp頁面名稱為define.asp,則只要在對應(yīng)asp頁面中加入以下語句就能引入該頁面。

<!--#INCLUDE VIRTUAL="/define.asp" -->
在進(jìn)行頁面引進(jìn)時,最好在待引進(jìn)的asp文件中不要包含<%@LANGUAGE="VBSCRIPT"%>語句。因為在asp文件中,只能有一句由@來定義的腳本解析語言。

8、安全防護(hù)

asp提供了很好的代碼保護(hù)機制,所有的asp代碼都在服務(wù)器端執(zhí)行而只返回給客戶端代碼執(zhí)行結(jié)果。即便這樣,在老版本的IIS中還可以在文件名后面家::$DATA來查看asp的源代碼,這已經(jīng)屬于Web Server安全范疇不在本文討論范圍內(nèi)。下面提出兩點簡單的安全注意事項。

雖然在asp中建議引入文件以inc作為擴(kuò)展名,在這里仍建議以asp作為引文件的擴(kuò)展名。當(dāng)這些代碼在安全機制不好的Web Server上運行時,只需在地址欄上輸入引入文件的地址(inc為擴(kuò)展名),就可以瀏覽該引入文件的內(nèi)容,這是由于在Web Server上,如果沒有定義好解析某類型(比如inc)的動態(tài)連接庫時,該文件以源碼方式顯示。

不要把數(shù)據(jù)庫文件放在網(wǎng)站結(jié)構(gòu)內(nèi)部,這樣,當(dāng)惡意人士獲取數(shù)據(jù)庫路徑后,就可以輕易獲取該數(shù)據(jù)庫,進(jìn)而肆意更改數(shù)據(jù)庫內(nèi)容。比較好的做法是,為數(shù)據(jù)庫建立DSN(Date Source Name),而在進(jìn)行數(shù)據(jù)庫訪問時直接訪問該DSN。

通過本文關(guān)于ASP編碼的八條原則介紹,希望能夠給你帶來幫助。

標(biāo)簽: ASP
相關(guān)文章:
主站蜘蛛池模板: 宏源科技-房地产售楼系统|线上开盘系统|售楼管理系统|线上开盘软件 | 厦门ISO认证|厦门ISO9001认证|厦门ISO14001认证|厦门ISO45001认证-艾索咨询专注ISO认证行业 | 马尔表面粗糙度仪-MAHR-T500Hommel-Mitutoyo粗糙度仪-笃挚仪器 | 浙江寺庙设计-杭州寺院设计-宁波寺庙规划_汉匠 | 厂房出租_厂房出售_产业园区招商_工业地产&nbsp;-&nbsp;中工招商网 | 耐酸泵,耐腐蚀真空泵,耐酸真空泵-淄博华舜耐腐蚀真空泵有限公司 精密模具-双色注塑模具加工-深圳铭洋宇通 | 打造全球沸石生态圈 - 国投盛世| 电竞馆加盟,沈阳网吧加盟费用选择嘉棋电竞_售后服务一体化 | 杭州标识标牌|文化墙|展厅|导视|户内外广告|发光字|灯箱|铭阳制作公司 - 杭州标识标牌|文化墙|展厅|导视|户内外广告|发光字|灯箱|铭阳制作公司 | 订做不锈钢_不锈钢定做加工厂_不锈钢非标定制-重庆侨峰金属加工厂 | 垃圾压缩设备_垃圾处理设备_智能移动式垃圾压缩设备--山东明莱环保设备有限公司 | 安徽合肥格力空调专卖店_格力中央空调_格力空调总经销公司代理-皖格制冷设备 | 成都顶呱呱信息技术有限公司-贷款_个人贷款_银行贷款在线申请 - 成都贷款公司 | 辊道窑炉,辊道窑炉厂家-山东艾希尔 | 上海刑事律师|刑事辩护律师|专业刑事犯罪辩护律师免费咨询-[尤辰荣]金牌上海刑事律师团队 | 胶水,胶粘剂,AB胶,环氧胶,UV胶水,高温胶,快干胶,密封胶,结构胶,电子胶,厌氧胶,高温胶水,电子胶水-东莞聚力-聚厉胶粘 | 防渗土工膜|污水处理防渗膜|垃圾填埋场防渗膜-泰安佳路通工程材料有限公司 | 无硅导热垫片-碳纤维导热垫片-导热相变材料厂家-东莞市盛元新材料科技有限公司 | 不干胶标签-不干胶贴纸-不干胶标签定制-不干胶标签印刷厂-弗雷曼纸业(苏州)有限公司 | 木材烘干机,木炭烘干机,纸管/佛香烘干设备-河南蓝天机械制造有限公司 | 影像测量仪_三坐标测量机_一键式二次元_全自动影像测量仪-广东妙机精密科技股份有限公司 | 旋转滴界面张力仪(张力测定仪器)-百科| 节流截止放空阀-不锈钢阀门-气动|电动截止阀-鸿华阀门有限公司 | 南京试剂|化学试剂|分析试剂|实验试剂|cas号查询-专业60年试剂销售企业 | 拉力机-万能试验机-材料拉伸试验机-电子拉力机-拉力试验机厂家-冲击试验机-苏州皖仪实验仪器有限公司 | 长春网站建设,五合一网站设计制作,免费优化推广-长春网站建设 | 儿童语言障碍训练-武汉优佳加感统文化发展有限公司 | 中式装修设计_室内中式装修_【云臻轩】中式设计机构 | 涂层测厚仪_光泽度仪_uv能量计_紫外辐照计_太阳膜测试仪_透光率仪-林上科技 | 润滑油加盟_润滑油厂家_润滑油品牌-深圳市沃丹润滑科技有限公司 琉璃瓦-琉璃瓦厂家-安徽盛阳新型建材科技有限公司 | 高压负荷开关-苏州雷尔沃电器有限公司| COD分析仪|氨氮分析仪|总磷分析仪|总氮分析仪-圣湖Greatlake | 【铜排折弯机,钢丝折弯成型机,汽车发泡钢丝折弯机,线材折弯机厂家,线材成型机,铁线折弯机】贝朗折弯机厂家_东莞市贝朗自动化设备有限公司 | 北京公司注册_代理记账_代办商标注册工商执照-企力宝 | 超声波电磁流量计-液位计-孔板流量计-料位计-江苏信仪自动化仪表有限公司 | 胶原检测试剂盒,弹性蛋白检测试剂盒,类克ELISA试剂盒,阿达木单抗ELISA试剂盒-北京群晓科苑生物技术有限公司 | 120kv/2mA直流高压发生器-60kv/2mA-30kva/50kv工频耐压试验装置-旭明电工 | 上海道勤塑化有限公司 | 钢格板|热镀锌钢格板|钢格栅板|钢格栅|格栅板-安平县昊泽丝网制品有限公司 | 退火炉,燃气退火炉,燃气热处理炉生产厂家-丹阳市丰泰工业炉有限公司 | 贴板式电磁阀-不锈钢-气动上展式放料阀-上海弗雷西阀门有限公司 工业机械三维动画制作 环保设备原理三维演示动画 自动化装配产线三维动画制作公司-南京燃动数字 |