一个自己写的真正判断文件格式,文件大小,而并不仅仅从扩展名来进行判断的上传方法,进一步加强防止软件或恶意的木马图片上传

 

 if (FileUpload1.HasFile)
        {
            string filename = myfunction.UploadPic(this.FileUpload1, myfunction.Getcompanylogopath());
            if (filename.IndexOf("您") != -1)
            {
                Page.RegisterClientScriptBlock("err", "<script language=javascript>alert('" + filename + "');</script>");
            }
            else
            {
              
            }
        }

 

 

public string UploadPic(FileUpload FileUpload1,string SavePath)
        {
            string filename = string.Empty;
            string retstr = string.Empty;
            if (FileUpload1.HasFile)
            {
                string dirpath = SavePath;
                filename = FileUpload1.FileName;
                string[] myfile = filename.Split('.');
                int maxkb = this.GetUploadPicturemax();
                string newfilename = string.Empty;
                string dotname = myfile[myfile.Length - 1].ToString().ToLower();
                string folder = DateTime.Now.Year.ToString() + DateTime.Now.Month.ToString() + DateTime.Now.Day.ToString();
                if (dotname != "gif" && dotname != "jpg" && dotname != "png")
                {
               
                    retstr = "您上传的文件格式错误,请使用gif,jpg或png文件";
                }
                else
                {
                    try
                    {
                        if (FileUpload1.PostedFile.ContentLength / 1024 > maxkb)
                        {
                            retstr = "对不起,您上传的图片文件太大,最大不能超过" + maxkb.ToString() + "kb";
                            
                        }
                        else
                        {

                            if (!System.IO.Directory.Exists(dirpath + folder))
                            {
                                System.IO.Directory.CreateDirectory(dirpath + folder);
                            }
                            Random myrdn = new Random();
                            newfilename = DateTime.Now.Year.ToString() + DateTime.Now.Month.ToString() + DateTime.Now.Day.ToString() + DateTime.Now.Hour.ToString() + DateTime.Now.Minute.ToString() + DateTime.Now.Second.ToString() + myrdn.Next(10000).ToString() + "." + dotname;
                            FileUpload1.SaveAs(dirpath + folder + "//" + newfilename);
                            newfilename = folder + "//" + newfilename;
                            //继续判断图片的大小是否在指定范围内

                            System.Drawing.Image image = System.Drawing.Image.FromFile(dirpath + newfilename);
                            if (image.RawFormat.Guid != System.Drawing.Imaging.ImageFormat.Gif.Guid && image.RawFormat.Guid != System.Drawing.Imaging.ImageFormat.Jpeg.Guid && image.RawFormat.Guid != System.Drawing.Imaging.ImageFormat.Png.Guid)
                            {
                                //删除图片
                                image.Dispose();
                                if (System.IO.File.Exists(dirpath + newfilename))
                                    System.IO.File.Delete(dirpath + newfilename);
                                retstr = "对不起,您上传的图象格式为非法,请勿上传未知图片格式";
                              
                            }
                            else
                            {
                                image.Dispose();
                                retstr = filename;
                            }
                        }
                    }
                    catch
                    {
                        retstr = "对不起,您上传的图象格式为非法,请勿上传未知图片格式";
                        if (System.IO.File.Exists(dirpath + newfilename))
                            System.IO.File.Delete(dirpath + newfilename);

                    }

                }

            }
            return retstr;   
        } 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值