仓酷云
标题:
ASP网站制作之深切研讨“用ASP上载文件”(二)
[打印本页]
作者:
若相依
时间:
2015-1-16 22:27
标题:
ASP网站制作之深切研讨“用ASP上载文件”(二)
写软件都是想的时间比写的时间要长的.如果反过来了就得看看是什么原因了.另外大家可以回去问问公司里的小MM.(一般企业里,跟你们交付软件接触得最多的是她们)2、在ASP中实行
如今已得出结论,RFC1867是在WEB使用程序上载文件的最好体例。那末怎样来运转?Microsoft供应了甚么办法?别的有哪些办法能够用?
Microsoft的PostingAcceptor
ASP不撑持multipart/form-data编码体例,可是,Microsoft供应了收费的Posting Acceptor(http://www.microsoft.com/iis/support/iishelp/iis/htm/core/pareadme.htm),它是一个ISAPI使用程序,上载停止后,发生一个到ASP页的从头送达。(见ScottStanfield的文章issueofMIND(98年七月))。
SoftwareArtisans的SA-FileUp
SA-FileUp(http://www.softartisans.com/softartisans/saf.html)是最早的贸易举动服务器组件(ActiveServerComponents)之一。初版是97年5月入手下手利用的,如今全球包含Microsoft.com在内的上千个网站都在利用它。初期的Beta版本用ISAPI过滤器和举动服务器组件的团结体与ASP分离起来。接着,Microsoft推出了ASP1.0b(ASP.DLL1.15.14.0),供应了一种新办法:Request.BinaryRead(二进制读哀求)。二进制读办法使扫瞄器中的原始未加工数据能够被举动服务器组件利用。如许一来,SA-FileUp就不再必要ISAPI过滤器,而作为一个ASP组件存在了。
SA-FileUp利用二进制读哀求,而不是经由过程表单工具。如许是成心义的:你怎能一边从扫瞄器读原始数据流,又同时把它作为表信息来剖析呢?为了照应ASP开辟职员,SA-FileUp在它本人的表集里从头供应了一切的表哀求功效。如许使习气于利用表哀求的ASP编程职员对SA-FileUp可以加倍熟习。
PostingAcceptor与SA-FileUp之对照
如今就PA和SA-FileUp举行一个尽量客不雅的对照:
■与ASP的分离性:SA-FileUp在ASP中是完整可剧本化的,它能够与ASP使用程序很好地分离起来,而不是作为一个自力的ISAPIDLL存在。
■尺度撑持性:从IE扫瞄器举行PA上载要利用其独有的WebPostAPI,以是不如RFC1867,利用PA,关于Netscape和IE用户要利用分歧的格局。
■匿名毗连:因为PA利用一个ISAPIDLL,在ASP使用程序之外它就必需供应分外的平安回护。因而在默许形态下PA不同意统统匿名毗连。PA1.1能够同意匿名上载,可是由于有一个上载的编程把持,这里仍旧有必定的伤害。因为SA-FileUp已和ASP分离在一同,使用程序能够决意得当的平安度,包含匿名。
■上载把持:上载正在发送时,PA不同意任何把持。可是用SA-FileUp,能够限定上载的范围或及时决意作废上载。而最好的一点在于能够静态改动上载的地位。
■处置历程:PA有两步:上载和从头送达。用SA-FileUp,统统都能够一步完成,比方依据上载的形态写数据库。
■上载到一个数据库:PA只能上载到文件,SA-FileUp可上载到文件和数据库。
■“文件名中的空格”:当处置含有空格的文件名时,PA存在成绩;SA-FileUp就没有如许的毛病。
■代价:PA可从Microsoft收费下载,与NT选项软择包绑缚在一同。而SA-FileUp不是收费的:它是有撑持的贸易组件。
VertigoSoftware的总裁ScottStanfield(http://www.vertigosoftware.com/),是MIND杂志98年7月号上PostAccetpor文章的作者,MIND上的文章宣布以后,在SoftwareArtisans上关于SA-FileUp,他又写道:“晓得了[SA-FileUp]十分镇静,这真是奇奥而有代价的产物。”
配合的撑持成绩
到如今为止,有关文件上载的撑持成绩次要是与平安有关的。一般网站都太过当心地回护NTFS允许,它能够避免匿名用户帐号向文件目标地点中举行写进。并且即便是初级服务器办理员也常常毛病了解平安的寄义。
要记着,IIS/ASP在一个出格的平安情况下运转每一个ASP页。假如没有判别机制(没有Basic,没有NTChallenge/Response),每页都作为匿名用户实行。收集办理员能够设置与匿名用户响应的NT帐号。
关于IIS3,默许的匿名用户是IUSR_<computername>。
关于IIS4,一切运转中的收集使用程序的默许匿名用户都是IUSR_<computername>(“在独自的内存空间运转”不被检察)。一切运转之外的使用程序的默许匿名用户是IWAM_<computername>(“在独自的内存空间运转”被检察)。
利用SA-FileUp时,必需包管得当的用户对目标路径有读、写、删除允许。
假如判别功效发扬感化,在运转ASP页的过程当中IIS/ASP就将饰演已判别的用户。因而经判别用户的注册帐号对目标路径必需有读、写、删除允许。
对IIS平安的深切会商已凌驾了本文的局限,theIIS4ResourceKit有很好的注释。
一些代码
实际已充足了,上面来看一些ASP代码。
单个文件上载
上面是单个文件上载的一个复杂的HTML格局。
<HTML><HEAD> <TITLE>PleaseUploadYourFile</TITLE>
</HEAD><BODY> <formenctype="multipart/form-data"method="post"action="formresp.asp">
Enterfilenametoupload:<inputtype="file"name="f1"> <inputtype="submit"></form> </BODY></HTML>
上面是文件formresp.asp:
<%@LANGUAGE="VBSCRIPT"%>
<HTML><HEAD><TITLE>UploadFileResults</TITLE></HEAD>
<BODY>Thankyouforuploadingyourfile.
<%Setupl=Server.CreateObject("SoftArtisans.FileUp")%>
<%upl.SaveAs"C:empupload.out"%>
TotalBytesWritten:<%=upl.TotalBytes%>
</BODY></HTML>
有附加表单位素的文件上载
增添附加表单位素十分复杂。只需准确指定ENCTYPE,它就象任何一般HTML文件一样运转。
<HTML><HEAD><TITLE>PleaseUploadYourFile</TITLE>
</HEAD><BODY>
<formenctype="multipart/form-data"method="post"action="mformresp.asp">
Enterdescription:<inputtype="text"name="descrip"> Enterfilenametoupload:<inputtype="file"name="f1"> <inputtype="submit"></form>
</BODY></HTML>
上面是文件mformresp.asp:
<%@LANGUAGE="VBSCRIPT"%><HTML><HEAD><TITLE>Upload
FileResults</TITLE></HEAD>
<BODY>
Thankyouforuploadingyourfile. <%Setupl=Server.CreateObject("SoftArtisans.FileUp")%>
<%upl.SaveAs"C:empupload.out"%> Yourdescriptionis:<%=upl.Form("descrip")%> TotalBytesWritten:<%=upl.TotalBytes%>
</BODY></HTML>
多文件上载
因为扫瞄器不撑持SIZE=属性,对多文件的情形就必需在每一个文件中都利用一个分外的<INPUT>语句。
Enterfirstfilename:<inputtype="file"name="f1"> Entersecondfilename:<inputtype="file"name="f2">
格局处置是一样的:
<%@LANGUAGE="VBSCRIPT"%><HTML><HEAD>
<TITLE>MultipleFileUploadResults</TITLE></HEAD>
<BODY>
Thankyouforuploadingyourfiles. <%Setupl=Server.CreateObject("SoftArtisans.FileUp")%> <%upl.Form("f1").SaveAs"C:empupload1.out"%> TotalBytesWrittenforfile1:<%=upl.Form("f1").TotalBytes%> <%upl.Form("f2").SaveAs"C:empupload2.out"%> TotalBytesWrittenforfile2:<%=upl.Form("f2").TotalBytes%> </BODY></HTML>
限定上载范围
要限定上载范围,只必要设置一个属性:
<%@LANGUAGE="VBSCRIPT"%><HTML><HEAD> <TITLE>UploadFileResults</TITLE></HEAD> <BODY>Thankyouforuploadingyourfile. <%Setupl=Server.CreateObject("SoftArtisans.FileUp")%> <%upl.MaxBytes=1000---limittheuploadsizeto1000bytes%> Themaximumsizethatyouarepermittedtouploadis<%=upl.MaxBytes%> bytesperfile. <%upl.SaveAs"C:empupload.out"%>TotalBytesWritten: <%=upl.TotalBytes%> ServerFilename:<%=upl.ServerName%> TotalBytesTransmittedbyyou:<%=Request.TotalBytes%> </BODY></HTML>
第1000个字节后的内容都将被删除,WEB服务器的磁盘就不会不用要地被占满。
结论
在WEB使用程序中完成上载文件十分复杂:戋戋两行ASP代码就可以完成。HTTP/RFC1867文件上载因服务器供应的丰厚的编程情况成为首选。SA-FileUp作为与ASP分离的举动服务器组件,比Microsoft的PostingAccetpro有分明上风。
使用cdonts,可以发送、查看邮件,实现webmail的功能。结合wsh,可以实现对nt主机的管理,如nt用户管理、iis虚拟主机设置、exchange邮箱设置等等,就像管理本地机一样方便。
作者:
山那边是海
时间:
2015-1-19 13:25
最近在学asp,不要问我为什么不直接学.net,因为公司网站是asp做的所以有这个需要,卖了本书asp入门到精通,对里面的六大内置对象老是记不住,还有很多属性和方法看的头晕。
作者:
再现理想
时间:
2015-1-28 06:36
你可以通过继承已有的对象最大限度保护你以前的投资。并且C#和C++、Java一样提供了完善的调试/纠错体系。
作者:
灵魂腐蚀
时间:
2015-2-5 17:01
下面简单介绍一下我学习ASP的方法,希望对想学习ASP的朋友有所帮助...
作者:
谁可相欹
时间:
2015-2-13 00:58
用户端的浏览器不需要提供任何别的支持,这样大提高了用户与服务器之间的交互的速度。
作者:
只想知道
时间:
2015-3-3 11:56
Server:这个表示的服务器,操作服务器的一些东西使用这个,如Server.Mappath转换服务器路径,Server.CreateObject实例化一个组件
作者:
小女巫
时间:
2015-3-11 10:50
以HTML语言整合(HTML负责界面上,ASP则负责功能上)形成一个B/S(浏览器/服务器)模式的网页程序。
作者:
第二个灵魂
时间:
2015-3-18 07:24
ASP.Net摆脱了以前ASP使用脚本语言来编程的缺点,理论上可以使用任何编程语言包括C++,VB,JS等等,当然,最合适的编程语言还是MS为.NetFrmaework专门推出的C(读csharp),它可以看作是VC和Java的混合体吧。
作者:
小妖女
时间:
2015-3-25 14:05
完全不知道到底自己学的是什么。最后,除了教程里面说的几个例子,还是什么都不会。
欢迎光临 仓酷云 (http://ckuyun.com/)
Powered by Discuz! X3.2