仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 421|回复: 8
打印 上一主题 下一主题

[学习教程] ASP编程:ASP程序完成图片上传的道理剖析及示例

[复制链接]
老尸 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-16 22:18:18 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
减少客户内IT专业人才缺乏带来的影响。ASP的客户员工利用浏览器进入相关的应用软件,简单易用,无需专业技术支持。程序|上传|示例用ASP编写网站使用程序工夫长了,不免会碰到形形色色的成绩,个中关于怎样上传文件到服务器生怕是碰见最多的成绩了,特别是上传图片,好比你想要在本人的社区内里完成相似网易假造社区供应的“逐日一星”的功效,就要供应给网友上传照片的功效。上传图片文件到服务器可使用各类收费的文件上传组件,利用起来功效固然很壮大,可是因为良多情形下,我们只能利用收费的撑持ASP的空间大概租用他人的假造空间,关于第一种情形,我们基本就没有大概来利用文件上传组件;至于第二种情形,我们也要支付很多的“银子”才能够。除非你具有本人的假造主机,你就能够任意的在服务器下面安装本人所必要的组件,这类情形关于年夜多半人来讲是可看而不成及的。那我们就没有举措了吗?呵呵,谜底是一定的(固然是一定的了,要否则我也没法写出这篇文章啊)。上面就让我们一同来利用纯ASP代码来完成图片的上传和保留到数据库的功效(特地也完成显现数据库中的图片到网页上的功效)。


起首我们先来熟习一下将要利用的工具办法。我们用来猎取上一个页面传送过去的数据通常为利用Request工具。一样的,我们也能够利用Request工具来猎取上传下去的文件数据,利用的办法是Request.BinaryRead()。而我们要从数据库中读出来图片的数据显现到网页下面要用到的办法是:
class=codeRequest.BinaryWrite()。在我们失掉了图片的数据,要保留到数据库中的时分,不成以间接利用Insert语句对数据库举行操纵,而是要利用ADO的AppendChunk办法,一样的,读出数据库中的图片数据,要利用GetChunk办法。各个办法的详细语法以下:
*Request.BinaryRead语法:
variant=Request.BinaryRead(count)
参数:
variant前往值保留着从客户端读取到数据。

count指明要从客户端读取的数据量巨细,这个值小于大概即是利用办法Request.TotalBytes失掉的数据量。
*Request.BinaryWrite语法:

Request.BinaryWritedata
参数:data要写进到客户端扫瞄器中的数据包。

*Request.TotalBytes语法:
variant=Request.TotalBytes
参数:variant前往从客户端读取到数据量的字节数。
*AppendChunk语法
将数据追加到年夜型文本、二进制数据Field或Parameter工具。
object.AppendChunkData
参数
objectField或Parameter工具
Data变体型,包括追加到工具中的数据。
申明:利用Field或Parameter工具的AppendChunk办法可将长二进制或字符数据填写到工具中。在体系内存无限的情形下,可使用AppendChunk办法对长整型值举行部分而非全体的操纵。
*GetChunk语法
前往年夜型文本或二进制数据Field工具的全体或部份内容。
variable=field.GetChunk(Size)
前往值:前往变体型。
参数:Size长整型表达式,即是所要检索的字节或字符数。
申明
利用Field工具的GetChunk办法检索其部分或全体长二进制或字符数据。在体系内存无限的情形下,可以使用GetChunk办法处置部分而非全体的长整型值。
GetChunk挪用前往的数据将赋给“变量”。假如Size年夜于残剩的数据,则GetChunk仅前往残剩的数据而无需用空缺添补“变量”。假如字段为空,则GetChunk办法前往Null。

每一个后续的GetChunk挪用将检索夙昔一次GetChunk挪用中断处入手下手的数据。可是,假如从一个字段检索数据然后在以后纪录中设置或读取另外一个字段的值,ADO将以为已从第一个字段中检索出数据。假如在第一个字段上再次挪用GetChunk办法,ADO将把挪用注释为新的GetChunk操纵并从纪录的肇端处入手下手读取。假如其他Recordset工具不是首个Recordset工具的正本,则会见个中的字段不会损坏GetChunk操纵。
假如Field工具的Attributes属性中的adFldLong位设置为True,则能够对该字段利用GetChunk办法。

假如在Field工具上利用Getchunk办法时没有以后纪录,将发生毛病3021(无以后纪录)。

接上去,我们就要来计划我们的数据库了,作为测试我们的数据库布局以下(Access2000):


字段称号    范例    形貌
 id   主动编号 主键值
imgOLE工具 用来保留图片数据 


关于在MSSQLServer7中,对应的布局以下:

字段称号    范例    形貌
 id    int(Identity) 主键值
img  image   用来保留图片数据
如今入手下手正式编写我们的纯ASP代码上传部分了,起首,我们有一个供应给用户的上传界面,可让用户选择要上传的图片。代码以下
(upload.htm):
<html>
<body>
<center>
<formname="mainForm"enctype="multipart/form-data"action="process.asp"method=p
ost>
  <inputtype=filename=mefile><br>
  <inputtype=submitname=okvalue="OK">
</form>
</center>
</body>
</html>
注重enctype="multipart/form-data",必定要在Form中有这个属性,不然,将没法失掉上传下去的数据。接上去,我们要在process.asp中对从扫瞄器中猎取的数据举行需要的处置,由于我们在process.asp中猎取到的数据不单单包括了我们想要的上传下去的图片的数据,也包括了其他的无用的信息,我们必要剔除冗余数据,并将处置过的图片数据保留到数据库中,这里我们以access2000为例。详细代码以下(process.asp):
<%
response.buffer=true
formsize=request.totalbytes
formdata=request.binaryread(formsize)
bncrlf=chrB(13)&chrB(10)
divider=leftB(formdata,clng(instrb(formdata,bncrlf))-1)
datastart=instrb(formdata,bncrlf&bncrlf)+4
dataend=instrb(datastart+1,formdata,divider)-datastart
mydata=midb(formdata,datastart,dataend)
setconnGraph=server.CreateObject("ADODB.connection")
connGraph.ConnectionString="driver={MicrosoftAccessDriver(*.mdb)};DBQ="&server.Ma
pPath("images.mdb")&";uid=;PWD=;"
connGraph.Open
setrec=server.createobject("ADODB.recordset")
rec.Open"SELECT*FROM[images]whereidisnull",connGraph,1,3
rec.addnew
rec("img").appendchunkmydata
rec.update
rec.close
setrec=nothing
setconnGraph=nothing
%>
好了,这下我们就把上传来的图片保留到了名为images.mdb的数据库中了,剩下的事情就是要将数据库中的图片数据显现到网页下面了。一样平常在HTML中,显现图片都是利用,可是我们的图片是保留到了数据库中,“图片路径”是甚么呢?呵呵,实在这个SRC属性除指定路径外,也能够如许利用哦:
<IMGSRC="showimg.asp?id=xxx">
以是,我们所要做的就是在showimg.asp中从数据库中读出来切合前提的数据,并前往到SRC属性中就能够了,详细代码以下(showimg.asp):
<%
setconnGraph=server.CreateObject("ADODB.connection")
connGraph.ConnectionString="driver={MicrosoftAccessDriver(*.mdb)};DBQ="&
server.MapPath("images.mdb")&";uid=;PWD=;"
connGraph.Open
setrec=server.createobject("ADODB.recordset")
strsql="selectimgfromimageswhereid="&trim(request("id"))
rec.openstrsql,connGraph,1,1
Response.ContentType="image/*"
Response.BinaryWriterec("img").getChunk(7500000)
rec.close
setrec=nothing
setconnGraph=nothing
%>
注重在输入到扫瞄器之前必定要指定Response.ContentType="image/*",
以便一般显现图片。
最初要注重的中央是,我的process.asp中作的处置没有思索到第一页(upload.htm)中另有其他数据,好比<INPUTtype=tesxtname=userid>等等,假如有这些项目,你的process.asp就要注重处置失落不用要的数据。
专业性的服务。有的ASP商提供垂直型的应用服务,针对某一特定行业提供应用服务。
小妖女 该用户已被删除
沙发
发表于 2015-1-19 07:31:02 | 只看该作者
不能只是将它停留在纸上谈兵的程度上。
精灵巫婆 该用户已被删除
板凳
发表于 2015-1-25 16:50:31 | 只看该作者
我想问如何掌握学习节奏(先学什么再学什么)最好详细点?
柔情似水 该用户已被删除
地板
发表于 2015-2-8 20:31:06 | 只看该作者
还有如何才能在最短的时间内学完?我每天可以有效学习2小时,双休日4小时。
飘灵儿 该用户已被删除
5#
发表于 2015-2-26 06:12:41 | 只看该作者
学习ASP其实应该上升到如何学习程序设计这种境界,其实学习程序设计又是接受一种编程思想。比如ASP如何学习,你也许在以前的学习中碰到过。以下我仔细给你说几点:
简单生活 该用户已被删除
6#
发表于 2015-3-8 12:31:05 | 只看该作者
他的语法和设计思路和VB完全相同,导致很多ASP的书都留一句“相关内容请参考VB的相关教材....”更糟糕的是,相当多的ASP教程混合了Javascript,VBscript等等脚本语言,搞的初学者。
山那边是海 该用户已被删除
7#
发表于 2015-3-15 23:55:56 | 只看该作者
ASP(ActiveServerPages)是Microsfot公司1996年11月推出的WEB应用程序开发技术,它既不是一种程序语言,也不是一种开发工具,而是一种技术框架,不须使用微软的产品就能编写它的代码,能产生和执行动态、交互式、高效率的站占服务器的应用程序。
海妖 该用户已被删除
8#
发表于 2015-3-22 18:10:28 | 只看该作者
学习ASP其实应该上升到如何学习程序设计这种境界,其实学习程序设计又是接受一种编程思想。比如ASP如何学习,你也许在以前的学习中碰到过。以下我仔细给你说几点:
admin 该用户已被删除
9#
发表于 2015-3-22 18:10:30 | 只看该作者
不是很难但是英文要有一点基础网上的教程很少有系统的详细的去买书吧,另不用专门学习vb关于vbscript脚本在asp教材都有介绍
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2025-1-12 00:29

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表