| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 473 人关注过本帖
标题:在编辑器里如何不能上传不是真正的 图片呢?
只看楼主 加入收藏
liaohongchu
Rank: 1
等 级:新手上路
帖 子:133
专家分:0
注 册:2008-4-25
结帖率:78.72%
收藏
已结贴  问题点数:10 回复次数:2 
在编辑器里如何不能上传不是真正的 图片呢?
为什么检查文件是否为图片文件不成功呢
在编辑器了的 就不成功,如果是想单独上传的文件的 话 就可以判断不是图片文件的 话就无法上传
在编辑器里如何不能上传不是真正的 图片呢?

'******************************************************************
'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
'判断是否为真正的图片文件结束
搜索更多相关主题的帖子: 编辑器 
2009-09-26 11:07
aspic
Rank: 17Rank: 17Rank: 17Rank: 17Rank: 17
等 级:贵宾
威 望:51
帖 子:2258
专家分:8050
注 册:2008-2-18
收藏
得分:10 
你是要问还是要共享?
2009-09-26 11:50
liaohongchu
Rank: 1
等 级:新手上路
帖 子:133
专家分:0
注 册:2008-4-25
收藏
得分:0 
是问的 ?就是 编辑器里上传图片也不能传不是真正的图片文件 。
比如:1.asp 改成1.jpg页不能上传成功 我上面的代码不成功的 ?奇怪了 哪里错了 。
2009-09-29 09:38
快速回复:在编辑器里如何不能上传不是真正的 图片呢?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.038387 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved