注册 登录
编程论坛 ASP技术论坛

在编辑器里如何不能上传不是真正的 图片呢?

liaohongchu 发布于 2009-09-26 11:07, 473 次点击
为什么检查文件是否为图片文件不成功呢
在编辑器了的 就不成功,如果是想单独上传的文件的 话 就可以判断不是图片文件的 话就无法上传
在编辑器里如何不能上传不是真正的 图片呢?

'******************************************************************
'CheckFileType 函数用来检查文件是否为图片文件
'参数filename是本地文件的路径
'如果是文件jpeg,gif,bmp,png图片中的一种,函数返回true,否则返回false
'******************************************************************
const adTypeBinary=1

dim jpg(1):jpg(0)=CByte(&HFF):jpg(1)=CByte(&HD8)
dim bmp(1):bmp(0)=CByte(&H42):bmp(1)=CByte(&H4D)
dim png(3):png(0)=CByte(&H89):png(1)=CByte(&H50):png(2)=CByte(&H4E):png(3)=CByte(&H47)
dim gif(5):gif(0)=CByte(&H47):gif(1)=CByte(&H49):gif(2)=CByte(&H46):gif(3)=CByte(&H39):gif(4)=CByte(&H38):gif(5)=CByte(&H61)

function CheckFileType(filename)
CheckFileType=false
dim fstream,fileExt,stamp,i
fileExt=mid(filename,InStrRev(filename,".")+1)
set fstream=Server.createobject("ADODB.Stream")
fstream.Open
fstream.Type=adTypeBinary
fstream.LoadFromFile filename
fstream.position=0
select case fileExt
case "jpg","jpeg"
stamp=fstream.read(2)
for i=0 to 1
if ascB(MidB(stamp,i+1,1))=jpg(i) then CheckFileType=true else CheckFileType=false
next
case "gif"
stamp=fstream.read(6)
for i=0 to 5
if ascB(MidB(stamp,i+1,1))=gif(i) then CheckFileType=true else CheckFileType=false
next
case "png"
stamp=fstream.read(4)
for i=0 to 3
if ascB(MidB(stamp,i+1,1))=png(i) then CheckFileType=true else CheckFileType=false
next
case "bmp"
stamp=fstream.read(2)
for i=0 to 1
if ascB(MidB(stamp,i+1,1))=bmp(i) then CheckFileType=true else CheckFileType=false
next
end select
fstream.Close
set fseteam=nothing
if err.number <>0 then CheckFileType=false
end function
'-------------判断是否为图片文件结束

Call CheckValidExt(sFileExt)
sOriginalFileName = oFile.FileName
sSaveFileName = GetRndFileName(sFileExt)
oFile.SaveToFile Server.Mappath(sUploadDir & sSaveFileName)
  '判断是否为真正的图片文件开始
  FileName=sUploadDir & sSaveFileName
If not CheckFileType(Server.mappath(FileName)) then '检查是否图片文件
      'response.write " <center>错误的图像格式  [ <a href=# onclick=history.go(-1)>重新上传 </a> ] </center>"
      Set fso = CreateObject("Scripting.FileSystemObject")
      Set ficn = fso.GetFile(Server.mappath(FileName))
      ficn.delete
      set ficn=nothing
      set fso=nothing
      
      'call msg("错误的图像格式,请重新上传!","-1")
      response.Write " <script> alert('错误的图像格式,请重新上传');history.go(-1); </script>"
      'response.end
end if
'判断是否为真正的图片文件结束
2 回复
#2
aspic2009-09-26 11:50
你是要问还是要共享?
#3
liaohongchu2009-09-29 09:38
是问的 ?就是 编辑器里上传图片也不能传不是真正的图片文件 。
比如:1.asp 改成1.jpg页不能上传成功 我上面的代码不成功的 ?奇怪了 哪里错了 。
1