1.如何用Asp判断你的网站的虚拟物理路径
答:使用Mappath方法
<palign="center"><fontsize="4"face="Arial"><b>
ThePhysicalpathtothisvirtualwebsiteis:
</b></font>
<fontcolor="#FF0000"size="6"face="Arial">
<%=Server.MapPath("\")%>
</font></p>
答:使用theRequestobject方法
strBrowser=Request.ServerVariables("HTTP_USER_AGENT")
IfInstr(strBrowser,"MSIE")<>0Then
Response.redirect("ForMSIEOnly.htm")
Else
Response.redirect("ForAll.htm")
EndIf
答:解决方法
<%startdate=DateDiff("d",Now,"01/01/1990")
ifstrdate<0thenstartdate=startdate*-1
avgvpd=Int((usercnt)/startdate)%>
显示结果
<%response.write(avgvpd)%>
thatisit.thispagehavebeenviewedsinceNovember10,1998
<%dimp,ppic,dpic
ppic=12
randomize
p=Int((ppic*rnd)+1)
dpic="graphix/randompics/"&p&".gif"
%>
显示
<imgsrc="<%=dpic%>">
答:<ahref="<%=request.serverVariables("Http_REFERER")%>">preivouspage</a>
或用图片如:<imgsrc="arrowback.gif"alt="<%=request.serverVariables("HTTP_REFERER")%>">
答:<%=Request.serverVariables("REMOTE_ADDR)%>
答:<%@Languages=vbscript%>
<%response.expires=0
strimagename="graphix/errors/erroriamge.gif"
response.redirect(strimagename)
%>
答:把这句话放载页面的开头
<%response.status="401notAuthorized"
response.end
%>
答:用HIDDEN类型来传递变量
<%formmethod="post"action="mynextpage.asp">
<%foreachiteminrequest.form%>
<inputnamee="<%=item%>"type="HIDDEN"
value="<%=server.HTMLEncode(Request.form(item))%>">
<%next%>
</form>
答:由于asp是服务器运行的,如果可以在服务器显示一个对话框,那么你只好等有人按了确定之后,你的程序才能继续执行,而一般服务器不会有人守着,所以微软不得不禁止这个函数,并胡乱告诉你(:)呵呵)没有权限。但是ASP和客户端脚本结合倒可以显示一个对话框,asfollows:
<%yourVar="测试对话框"%>
<%scriptlanguage='javascript'>
alert("<%=yourvar%>")
</script>
答:可以去下载一个微软的WindowsScriptEncoder,它可以对asp的脚本和客户端javascript/vbscript脚本进行加密。。。不过客户端加密后,只有ie5才能执行,服务器端脚本加密后,只有服务器上安装有scriptengine5(装一个ie5就有了)才能执行。
答:前者文件加入下句:Response.Redirect("second.asp?"&Request.ServerVariables("QUERY_STRING"))
答:只有web目录设置为webapplication,global.asa才有效,并且一个webapplication的根目录下global.asa才有效。IIS4可以使用InternetServiceManager设置applicationsetting怎样才能使得htm文件如同asp文件一样可以执行脚本代码?
答:InternetSevicesManager->选择defaultwebsite->右鼠键->菜单属性-〉主目录->应用程序设置(ApplicationSetting)->点击按钮"配置"->appmapping->点击按钮"Add"->executablebrowse选择\WINNT\SYSTEM32\INETSRV\ASP.DLLEXTENSION输入htmmethodexclusions输入PUT.DELETE全部确定即可。但是值得注意的是这样对htm也要由asp.dll处理,效率将降低。
答:有两种方法。
第一种方法:手工注册DLL这种方法从IIs3.0一直使用到IIs4.0和其它的WebServer。它需要你在命令行方式下来执行,进入到包含有DLL的目录,并输入:regsvr32component_name.dll例如c:\temp\regsvr32AspEmail.dll它会把dll的特定信息注册入服务器中的注册表中。然后这个组件就可以在服务器上使用了,但是这个方法有一个缺陷。当使用这种方法注册完毕组件后,该组件必须要相应的设置NT的匿名帐号有权限执行这个dll。特别是一些组件需要读取注册表,所以,这个注册组件的方法仅仅是使用在服务器上没有MTS的情况下,要取消注册这个dll,使用:regsvr32/uaspobject.dllexamplec:\temp\regsvr32/uaneiodbc.dll
第二种方法:使用MTS(MicrosoftTransactionServer)MTS是IIS4新增特色,但是它提供了巨大的改进。MTS允许你指定只有有特权的用户才能够访问组件,大大提高了网站服务器上的安全性设置。在MTS上注册组件的步骤如下:
1)打开IIS管理控制台。
2)展开transactionserver,右键单击"pkgsinstalled"然后选择"newpackage"。
3)单击"createanemptypackage"。
4)给该包命名。
5)指定administrator帐号或则使用"interactive"(如果服务器经常是使用administrator登陆的话)。
6)现在使用右键单击你刚建立的那个包下面展开后的"components"。选择"newthencomponent"。
7)选择"installnewcomponent"。
8)找到你的.dll文件然后选择next到完成。
要删除这个对象,只要选择它的图标,然后选择delete。
附注:特别要注意第二种方法,它是用来调试自己编写组件的最好方法,而不必每次都需要重新启动机器了。
<%@language=VBscript%>
<%
dimconn,mdbfile
mdbfile=server.mappath("数据库名称.mdb")
setconn=server.createobject("adodb.connection")
conn.open"driver={microsoftaccessdriver(