社区应用 最新帖子 精华区 社区服务 会员列表 统计排行 社区论坛任务 迷你宠物
  • 3729阅读
  • 0回复

ASP编程中20个非常有用的例子

级别: 店掌柜
发帖
5692
铜板
103378
人品值
1520
贡献值
26
交易币
0
好评度
5373
信誉值
0
金币
0
所在楼道

1.如何用Asp判断你的网站的虚拟物理路径 6jgP/~hP>N  
答:使用Mappath方法 f+s)A(?3  
< p align="center" >< font size="4" face="Arial" >< b > PI`Y%!P  
The Physical path to this virtual website is: 0|j44e }  
< /b >< /font > W'"?5} (  
< font color="#FF0000" size="6" face="Arial" > )uo".n|n~B  
< %= Server.MapPath("\")% > eWex/ m  
< /font >< /p > fiA8W  
2.我如何知道使用者所用的浏览器? x4wTQ$*1  
答:使用the Request object方法 wEX<[#a-  
strBrowser=Request.ServerVariables("HTTP_USER_AGENT") o -)[{o\  
If Instr(strBrowser,"MSIE") < > 0 Then d-e/0F!  
  Response.redirect("ForMSIEOnly.htm") G!I5Er0pdy  
Else CdmpKkq#  
  Response.redirect("ForAll.htm") w+*rbJ  
End If 71P. 9Iz  
![r)KE=v8I  
3.如何计算每天的平均反复访问人数 0)b1'xt',  
答:解决方法 .JB1#&B +  
< % startdate=DateDiff("d",Now,"01/01/1990") F*Hovxez  
if strdate< 0 then startdate=startdate*-1 Vjt7X"_/  
avgvpd=Int((usercnt)/startdate) % > H!X*29nX  
显示结果 W5Pur lu?  
< % response.write(avgvpd) % > Te?PYV-  
that is it.this page have been viewed since November 10,1998 &-Wt!X 3  
>yn]h4M  
4.如何显示随机图象 lt:&lIW,3  
< % dim p,ppic,dpic c!wRq4  
ppic=12  + @f  
randomize _xi &%F/  
p=Int((ppic*rnd)+1) j #P4&  
dpic="graphix/randompics/"&p&".gif" /|UbYe,  
% > oPaoQbR(A  
显示 +4T.3Njjn  
< img src="< %=dpic% >" > F}meKc?a  
Vn{;8hZ :a  
5.如何回到先前的页面 ^OIo  
答:< a href="< %=request.serverVariables("Http_REFERER")% >" >preivous page< /a > ^q/^.Gf  
或用图片如:< img src="arrowback.gif" alt="< %=request.serverVariables("HTTP_REFERER")% >" > &1^~G0 Rh\  
OGJrwl  
6.如何确定对方的IP地址 w_@{v wM$A  
答:< %=Request.serverVariables("REMOTE_ADDR)% > qk3 ~]</  
.-& =\}^2l  
7.如何链结到一副图片上 -UzWLVB^  
答:< % @Languages=vbscript % > NopfL  
< % response.expires=0 MMET^SO  
strimagename="graphix/errors/erroriamge.gif" $E^sA|KcT  
response.redirect(strimagename) rDoMz3[w  
% > -]u>kjiIT  
is^R8a  
8.强迫输入密码对话框 y&8`NS#_p?  
答:把这句话放载页面的开头 -@#],s7  
< % response.status="401 not Authorized" <kwF<J  
response.end v< 2,OcH  
% > V?x&\<;,  
E)jd>"  
9.如何传递变量从一页到另一页 Bd=K40Z:  
答:用 HIDDEN 类型来传递变量 h,BPf5\S  
< % form method="post" action="mynextpage.asp" > $t"QLsk0  
< % for each item in request.form % > mSu$1m8  
< input namee="< %=item% >" type="HIDDEN" *& );-r`.  
value="< %=server.HTMLEncode(Request.form(item)) % >" > Sw-2vnSdM  
< % next % > dJ])`S  
< /form > i(.PkYkaq  
Ev [?5R  
10.为何我在 asp 程序内使用 msgbox,程序出错说没有权限 <im}R9eJ1  
答:由于 asp 是服务器运行的,如果可以在服务器显示一个对话框,那么你只好等有人按了确定之后,你的程序才能继续执行,而一般服务器不会有人守着,所以微软不得不禁止这个函数,并胡乱告诉你 (:) 呵呵) 没有权限。但是ASP和客户端脚本结合倒可以显示一个对话框,as follows: @zi0:3`#0\  
<%yourVar="测试对话框"%> pG)dF@  
<script language='javascript'> l,b,U/3R.  
alert("<%=yourvar%>") ZTfW_0   
</script> gYGoJH1  
[] "bn9 +  
11.有没有办法保护自己的源代码,不给人看到 )t-P o'RW  
答:可以去下载一个微软的Windows Script Encoder,它可以对asp的脚本和客户端javascript/vbscript脚本进行加密。。。不过客户端加密后,只有ie5才能执行,服务器端脚本加密后,只有服务器上安装有script engine 5(装一个ie5就有了)才能执行。 m3P7*S5NJ7  
,f,+)C$  
12.怎样才能将 query string 从一个 asp 文件传送到另一个? IV':sNV  
答:前者文件加入下句: Response.Redirect("second.asp?" & Request.ServerVariables("QUERY_STRING")) ~.U \Y  
hH;i_("i(h  
13.global.asa文件总是不起作用? f]?&R c2C  
答:只有web目录设置为web application, global.asa才有效,并且一个web application的根目录下 global.asa才有效。IIS4可以使用Internet Service Manager设置application setting 怎样才能使得htm文件如同asp文件一样可以执行脚本代码? 06.8m;{N  
w^nA/=;r  
14.怎样才能使得htm文件如同asp文件一样可以执行脚本代码? ]K>bSK^TX  
答:Internet Sevices Manager - > 选择default web site - >右鼠键- >菜单属性-〉主目录- > 应用程序设置(Application Setting)- > 点击按钮 "配置"- > app mapping - >点击按钮"Add" - > executable browse选择 \WINNT\SYSTEM32\INETSRV\ASP.DLL EXTENSION 输入 htm method exclusions 输入PUT.DELETE 全部确定即可。但是值得注意的是这样对htm也要由asp.dll处理,效率将降低。 `<<9A\Y-f  
>>C S8  
15.如何注册组件 RX?!MDO  
答:有两种方法。 l"X,[  
第一种方法:手工注册 DLL 这种方法从IIs 3.0一直使用到IIs 4.0和其它的Web Server。它需要你在命令行方式下来执行,进入到包含有DLL的目录,并输入:regsvr32 component_name.dll 例如 c:\temp\regsvr32 AspEmail.dll 它会把dll的特定信息注册入服务器中的注册表中。然后这个组件就可以在服务器上使用了,但是这个方法有一个缺陷。当使用这种方法注册完毕组件后,该组件必须要相应的设置NT的匿名帐号有权限执行这个dll。特别是一些组件需要读取注册表,所以,这个注册组件的方法仅仅是使用在服务器上没有MTS的情况下,要取消注册这个dll,使用:regsvr32 /u aspobject.dll example c:\temp\regsvr32 /u aneiodbc.dll &c&TQkx  
1?8M31  
第二种方法:使用MTS(Microsoft Transaction Server) MTS是IIS 4新增特色,但是它提供了巨大的改进。MTS允许你指定只有有特权的用户才能够访问组件,大大提高了网站服务器上的安全性设置。在MTS上注册组件的步骤如下: xpuTh"ED  
1) 打开IIS管理控制台。 `#`C.:/n  
2) 展开transaction server,右键单击"pkgs installed"然后选择"new package"。 ..'"kX:5  
3) 单击"create an empty package"。 8 E l hcs  
4) 给该包命名。 !~'D;Jh  
5) 指定administrator帐号或则使用"interactive"(如果服务器经常是使用administrator 登陆的话)。 oPbziB8  
6) 现在使用右键单击你刚建立的那个包下面展开后的"components"。选择 "new then component"。 w7pX]<?R"  
7) 选择 "install new component" 。 46\!W(O~y  
8) 找到你的.dll文件然后选择next到完成。 W)  
要删除这个对象,只要选择它的图标,然后选择delete。 LqJV  
附注:特别要注意第二种方法,它是用来调试自己编写组件的最好方法,而不必每次都需要重新启动机器了。 NhF"%  
S-Vxlku]  
16. ASP与Access数据库连接: x 00'wY|  
wnXU=  
<%@ language=VBscript%> E1Q#@*rX>  
<% |<oqT+?i  
dim conn,mdbfile ;Q/1l=Bn  
mdbfile=server.mappath("数据库名称.mdb") ?-`&YfF  
set conn=server.createobject("adodb.connection") OQ<;w  
conn.open "driver={microsoft access driver (*.mdb)};uid=admin;pwd=数据库密码;dbq="&mdbfile ""N~##)8  
W[Z[o+7pK  
%> u:W/6QS  
152s<lu1Z  
17. ASP与SQL数据库连接: Ks(l :oUB  
\{a5]G(4s  
<%@ language=VBscript%> I|;zGmg#k  
<% ".( G,TW  
dim conn &><b/,]  
set conn=server.createobject("ADODB.connection") tr/.pw6  
con.open "PROVIDER=SQLOLEDB;DATA SOURCE=SQL服务器名称或IP地址;UID=sa;PWD=数据库密码;DATABASE=数据库名称 ?GLCd7TP  
%> v6L]3O1  
w6mYLK%  
建立记录集对象: @/$i -?E  
!>Q\Y`a,*  
set rs=server.createobject("adodb.recordset") Sz1J4$5  
rs.open SQL语句,conn,3,2 ~Ij/vyB_  
J#3[,~  
<KCyXU*  
18. SQL常用命令使用方法: }jWg&<5+z  
M5_ t#[ [  
(1) 数据记录筛选: 368 g> /#'  
4:b'VHW.  
sql="select * from 数据表 where 字段名=字段值 order by 字段名 [desc]" @PQd6%@  
z?|bs?HKS  
sql="select * from 数据表 where 字段名 like '%字段值%' order by 字段名 [desc]" [fvjvN`  
r5(efTgAd+  
sql="select top 10 * from 数据表 where 字段名 order by 字段名 [desc]" H`q[!5~8  
@"^7ASd%  
sql="select * from 数据表 where 字段名 in ('值1','值2','值3')" JdWav!PYm  
o :4#Ak S  
sql="select * from 数据表 where 字段名 between 值1 and 值2" _E6N*ORV  
\GioSg  
(2) 更新数据记录: U^)`_\/;?  
^4<&"aoo  
sql="update 数据表 set 字段名=字段值 where 条件表达式" }m Ub1b  
EaL>~: j  
sql="update 数据表 set 字段1=值1,字段2=值2 …… 字段n=值n where 条件表达式" 2!b##`UjA7  
`Nz`5}8.?  
(3) 删除数据记录: WW^+X~Y  
`P:[.hRu  
sql="delete from 数据表 where 条件表达式" `@0AGSzUv  
}&6:0l$4!  
sql="delete from 数据表" (将数据表所有记录删除) 7;Q4k"h  
g\IwV+iDf  
(4) 添加数据记录: rp[3?-fk  
em- <V5fb  
sql="insert into 数据表 (字段1,字段2,字段3 …) valuess (值1,值2,值3 …)" H5UF r,t  
^/x\HGrw  
sql="insert into 目标数据表 select * from 源数据表" (把源数据表的记录添加到目标数据表) Rs"G8Q9Q  
n)35-?R/M  
(5) 数据记录统计函数: vO/3bu}  
Vu E$-)&)  
AVG(字段名) 得出一个表格栏平均值 HN5,MD[  
COUNT(*|字段名) 对数据行数的统计或对某一栏有值的数据行数统计 qFq$a9w|@  
MAX(字段名) 取得一个表格栏最大的值 WoNY8 8hT  
MIN(字段名) 取得一个表格栏最小的值 2vsV :LS.  
SUM(字段名) 把数据栏的值相加 /?z3*x  
+~y>22Zfg  
引用以上函数的方法: ,LmP >Q.  
$ye>;Ek  
sql="select sum(字段名) as 别名 from 数据表 where 条件表达式" x_C0=Q|K3  
set rs=conn.excute(sql) MtoOIkQ  
%@TC- xx  
用 rs("别名") 获取统的计值,其它函数运用同上。 =2} kiLKO  
vr2PCG[~  
(5) 数据表的建立和删除: ),xD5~_=q  
&"J;  
CREATE TABLE 数据表名称(字段1 类型1(长度),字段2 类型2(长度) …… ) N|Xm{@C  
H5:f&m  
例:CREATE TABLE tab01(name varchar(50),datetime default now()) V s=o@  
?Drq!?3PDc  
DROP TABLE 数据表名称 (永久性删除一个数据表) Ve)BF1YG  
M,bs`amz  
19. 记录集对象的方法: vEGI  
=]"I0G-s!  
rs.movenext 将记录指针从当前的位置向下移一行 |z:4T%ES  
rs.moveprevious 将记录指针从当前的位置向上移一行 [9NrPm3d  
rs.movefirst 将记录指针移到数据表第一行 0 ?gHRdU"  
rs.movelast 将记录指针移到数据表最后一行 ?0+g.,9  
rs.absoluteposition=N 将记录指针移到数据表第N行 G\V*j$}!  
rs.absolutepage=N 将记录指针移到第N页的第一行 &,{YfAxQ`  
rs.pagesize=N 设置每页为N条记录 Jo~fri([%Q  
rs.pagecount 根据 pagesize 的设置返回总页数 0!$y]Gr  
rs.recordcount 返回记录总数 yq^Ma  
rs.bof 返回记录指针是否超出数据表首端,true表示是,false为否 n%4/@M  
rs.eof 返回记录指针是否超出数据表末端,true表示是,false为否 _z 5W*..  
rs.delete 删除当前记录,但记录指针不会向下移动 +PKsiUJ|  
rs.addnew 添加记录到数据表末端 x)eoz2E1  
rs.update 更新数据表记录 MPw?HpM  
_jg tZ  
--------------------------------------- $7i[7S4  
Nv6"c<(L=  
20 Recordset对象方法 <dr2 bz  
6f ?,v5  
Open方法 . sFN[>)  
Vi}E9I4  
recordset.Open Source,ActiveConnection,CursorType,LockType,Options 4fjwC,,  
{B6ywTK\ `  
Source ~(GN Y5  
Recordset对象可以通过Source属性来连接Command对象。Source参数可以是一个Command对象名称、一段SQL命令、一个指定的数据表名称或是一个Stored Procedure。假如省略这个参数,系统则采用Recordset对象的Source属性。 v+SdjFAY  
'U0W   
ActiveConnection Z|ZB6gP>h1  
Recordset对象可以通过ActiveConnection属性来连接Connection对象。这里的ActiveConnection可以是一个Connection对象或是一串包含数据库连接信息(ConnectionString)的字符串参数。 e+{lf*"3  
=]/<Kd}A.  
CursorType ;/JXn  
Recordset对象Open方法的CursorType参数表示将以什么样的游标类型启动数据,包括adOpenForwardOnly、adOpenKeyset、adOpenDynamic及adOpenStatic,分述如下: 0'YP9-C3  
-------------------------------------------------------------- mo(>SnS<  
常数 常数值 说明 K' <[kh:cl  
------------------------------------------------------------- BfVh\ lkH  
adOpenForwardOnly 0 缺省值,启动一个只能向前移动的游标(Forward Only)。 BpYxH#4  
adOpenKeyset 1 启动一个Keyset类型的游标。 Y~UAE.  
adOpenDynamic 2 启动一个Dynamic类型的游标。 Zzz94`  
adOpenStatic 3 启动一个Static类型的游标。 <1<xSr  
------------------------------------------------------------- &oy')\H  
以上几个游标类型将直接影响到Recordset对象所有的属性和方法,以下列表说明他们之间的区别。 W7!iYxO  
w1aoEo"S  
------------------------------------------------------------- g%!U7CM6h  
Recordset属性 adOpenForwardOnly adOpenKeyset adOpenDynamic adOpenStatic *)6\ V}`  
------------------------------------------------------------- lmD [Cn  
AbsolutePage 不支持 不支持 可读写 可读写 n 9`]}bnX  
AbsolutePosition 不支持 不支持 可读写 可读写 G43r85LO  
ActiveConnection 可读写 可读写 可读写 可读写 {P_7AM  
BOF 只读 只读 只读 只读 Fkq^2o ]  
Bookmark 不支持 不支持 可读写 可读写 ;z N1Qb  
CacheSize 可读写 可读写 可读写 可读写 )c'E9ZuZ>d  
CursorLocation 可读写 可读写 可读写 可读写 m]8*k=v  
CursorType 可读写 可读写 可读写 可读写 W\;|mEEu  
EditMode 只读 只读 只读 只读 (j??  
EOF 只读 只读 只读 只读 +8itP>  
Filter 可读写 可读写 可读写 可读写 e"NP]_vh,  
LockType 可读写 可读写 可读写 可读写 #Nco|v  
MarshalOptions 可读写 可读写 可读写 可读写 :2,NKdD  
MaxRecords 可读写 可读写 可读写 可读写 \hBzP^*"n  
PageCount 不支持 不支持 只读 只读 VO=Ibu&X  
PageSize 可读写 可读写 可读写 可读写 uZ\+{j=  
RecordCount 不支持 不支持 只读 只读 L G5_\sY!  
Source 可读写 可读写 可读写 可读写 Vp|?R65S*  
State 只读 只读 只读 只读 xSSEDfq  
Status 只读 只读 只读 只读 tpO '<b  
AddNew 支持 支持 支持 支持 ,-8 -Y>[  
CancelBatch 支持 支持 支持 支持 5I^;v;F  
CancelUpdate 支持 支持 支持 支持 `M 'tuQ M  
Clone 不支持 不支持 ~ A=Gra  
Close 支持 支持 支持 支持 hwJ>IQ1  
Delete 支持 支持 支持 支持 =y)K er  
GetRows 支持 支持 支持 支持 g=@d!]Z~[  
Move 不支持 支持 支持 支持 ^+CHp(X  
MoveFirst 支持 支持 支持 支持 @|Yn~PwKs  
MoveLast 不支持 支持 支持 支持 $j<KXR  
MoveNext 支持 支持 支持 支持 voN~f>  
MovePrevious 不支持 支持 支持 支持 LyWY\K a  
NextRecordset 支持 支持 支持 支持 [wnp]'+!  
Open 支持 支持 支持 支持 #9!7-!4pW  
Requery 支持 支持 支持 支持 -GHd]7n  
Resync 不支持 不支持 支持 支持 {+E]c:{  
Supports 支持 支持 支持 支持 _ezRE"F5  
Update 支持 支持 支持 支持 IM/xBP  
UpdateBatch 支持 支持 支持 支持 x-X~'p'f  
-------------------------------------------------------------- BI%XF 9{  
其中NextRecordset方法并不适用于Microsoft Access数据库。 #u8#< ,w  
=|ODa/2 p  
LockType [3nWxFz$R  
Recordset对象Open方法的LockType参数表示要采用的Lock类型,如果忽略这个参数,那么系统会以Recordset对象的LockType属性为预设值。LockType参数包含adLockReadOnly、adLockPrssimistic、adLockOptimistic及adLockBatchOptimistic等,分述如下: dr:x0>  
mTxqcQc:7  
------------------------------------------------------------- N!3Tg564j  
常数 常数值 说明 $D!/v)3  
-------------------------------------------------------------- 2b^Fz0 w4  
adLockReadOnly 1 缺省值,Recordset对象以只读方式启动,无法运行AddNew、Update及Delete等方法 rqqd} kA  
adLockPrssimistic 2 当数据源正在更新时,系统会暂时锁住其他用户的动作,以保持数据一致性。 *q k7e[IP  
adLockOptimistic 3 当数据源正在更新时,系统并不会锁住其他用户的动作,其他用户可以对数据进行增、删、改的操作。 liH#=C8l*%  
adLockBatchOptimistic 4 当数据源正在更新时,其他用户必须将CursorLocation属性改为adUdeClientBatch才能对数据进行增、 'Kbrz  
删、改的操作。
评价一下你浏览此帖子的感受

精彩

感动

搞笑

开心

愤怒

无聊

灌水

简单生活
执著追求
别笑我浅溥,天真的以为用一腔真诚就能感动这个冷漠的世界。
也别说我幼稚,竟想用不长的人生去诠释繁杂的红尘。
然而除了真诚,我还能给你什么,的确我真的一无所有!

描述
快速回复

您目前还是游客,请 登录注册
批量上传需要先选择文件,再选择上传
认证码:
验证问题:
3+5=?,请输入中文答案:八 正确答案:八