|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
国内有些大的CRM厂商的ASP就写得不错.无论是概念还是它里面用JAVASCRIPT的能力.并不是说现在的程序员用了ASP.NET来写程序就可以说自己高档了上传|详解|上传这个成绩已不是甚么奇怪成绩了,网上也有年夜把的教程,但年夜多半是授人以鱼,而不授人以渔,经由辛劳的材料搜集,思索,调试,收拾,我基础上已把这个成绩从道理上弄分明了,如今依据我本人的了解,在典范程序的基本上,加以注释,但愿能对部分网友有所匡助。 请诸位年夜虾能对个中的不正或不良这处予以斧正。
我想循规蹈矩,先讲一个复杂的,单个图片文件保留到数据库。
这个典范共包含三个ASP文件和一个数据库(一个表),全体在统一目次下。
1、tblImage表布局(ACCESS2000)
sn 主动编号 序列号
content-type 文本 图片范例
image OLE工具 图片数据
2、SimpleImageToData.asp:上传表单及保留图片到数据库的代码部分,次要文件。
<%@Language=VBScript%>
<%optionexplicit%>
<%
从一个完全路径中析出文件称号
functiongetFileNamefromPath(strPath)
getFileNamefromPath=mid(strPath,instrrev(strPath,"")+1)
endfunction
界说数据库毗连字符串
dimcnstr
cnstr="driver={MicrosoftAccessDriver(*.mdb)};dbq="&server.MapPath("./upload.mdb")
%>
<HTML>
<HEAD>
<title>单个图象保留到数据库</title>
<metahttp-equiv="Content-Type"content="text/html;charset=gb2312">
</HEAD>
<body>
<p><ahref="SimpleImageToData.asp">上传图片</a>
<ahref="ShowImageListFromData.asp">显现图片</a><hr></p>
<%
ifrequest.ServerVariables("REQUEST_METHOD")="POST"then
dimsCome,sGo,binData,strData
dimposB,posE,posSB,posSE
dimbinCrlf
dimstrPath,strFileName,strContentType
binCrlf=chrb(13)&chrb(10)界说一个单字节的回车换行符
setsCome=server.CreateObject("adodb.stream")
sCome.Type=1指定前往数据范例adTypeBinary=1,adTypeText=2
sCome.Mode=3指定翻开形式adModeRead=1,adModeWrite=2,adModeReadWrite=3
sCome.Open
sCome.Writerequest.BinaryRead(request.TotalBytes)
sCome.Position=0
binData=sCome.Read
response.BinaryWritebinData调试用:显现提交的一切数据
response.Write"<hr>"调试用
setsGo=server.CreateObject("adodb.stream")
sGo.Type=1
sGo.Mode=3
sGo.Open
posB=1
posB=instrb(posB,binData,binCrlf)
posE=instrb(posB+1,binData,binCrlf)
response.WriteposB&"|"&posE&"<br>"
sCome.Position=posB+1
sCome.CopyTosGo,posE-posB-2
sGo.Position=0
sGo.Type=2
sGo.Charset="gb2312"
strData=sGo.ReadText
sGo.Close
response.WritestrData&"<hr>"
posSB=1
posSB=instr(posSB,strData,"filename=""")+len("filename=""")
posSE=instr(posSB,strData,"""")
ifposSE>posSBthen
strPath=mid(strData,posSB,posSE-posSB)
response.Write"当地路径:"&strPath&"<br>"
response.Write"文件名:"&getFileNamefromPath(strPath)&"<br>"
posB=posE
posE=instrb(posB+1,binData,binCrlf)
response.WriteposB&"|"&posE&"<br>"
sGo.Type=1
sGo.Mode=3
sGo.Open
sCome.Position=posB
sCome.CopyTosGo,posE-posB-1
sGo.Position=0
sGo.Type=2
sGo.Charset="gb2312"
strData=sGo.ReadText
sGo.Close
strContentType=mid(strData,16)此处由于流动的,以是省略查找:-)
response.Write"图片范例:"&strContentType&"<hr>"
posB=posE+2
posE=instrb(posB+1,binData,binCrlf)
response.WriteposB&"|"&posE&"<br>"
sGo.Type=1
sGo.Mode=3
sGo.Open
sCome.Position=posB+1
sCome.CopyTosGo,posE-posB-2
sGo.Position=0
strData=sGo.Read
sGo.Close
response.Writelenb(strData)&"<br>"
dimcn,rs,sql
setcn=server.CreateObject("adodb.connection")
cn.Opencnstr
setrs=server.CreateObject("adodb.recordset")
sql="select*fromtblImage"
rs.Opensql,cn,1,3
rs.AddNew
rs.Fields("content-type").Value=strContentType
rs.Fields("image").AppendChunkstrData
rs.Update
rs.Close
setrs=nothing
&nbs
ASP在国内异常流行,因为国内大多使用的是盗版的Windows和盗版的SQLServer,而ASP+COM+SQLServer实际上也是一种不错的搭配,其性能也不输于PHP+MYSQL,特别是Windows系统和SQLServer都有图形界面,比APACHE和MYSQL易于维护,因此对于不重视知识产权的国家来说也是一种不错的选择。 |
|