if   (filetype   ==   "image/pjpeg"   ¦ ¦ 
拼错吧...

解决方案 »

  1.   

    to:silentwins
    的确有image/pjpeg这样的格式。我原以为asp.net 提供ContentType这样的属性就能够方便且安全的检查文件类型,看来我的确要检查文件后缀名了。
      

  2.   

    关于这个,如果不需对文件类型要求十分严格的话,还是检查扩展名算了。
    或者用另一种方法。
    以下代码来自清清月儿
     5.服务器端检查上传文件类型(可以检测真正文件名)
    其实方法4并不好,因为用户可以把XXX.txt伪装为XXX.jpg。效果图:后台代码:
    using System;
    using System.Data;
    using System.Configuration;
    using System.Collections;
    using System.Web;
    using System.Web.Security;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    using System.Web.UI.WebControls.WebParts;
    using System.Web.UI.HtmlControls;public partial class _Default : System.Web.UI.Page
    {
        //清清月儿 http://blog.csdn.net/21aspnet
        protected void Page_Load(object sender, EventArgs e)
        {    }
        protected void bt_upload_Click(object sender, EventArgs e)
        {
            try
            {
                if (FileUpload1.PostedFile.FileName == "")
                {
                    this.lb_info.Text = "请选择文件!";
                }
                else
                {
                    string filepath = FileUpload1.PostedFile.FileName;
                    if (IsAllowedExtension(FileUpload1) == true)
                    {
                        string filename = filepath.Substring(filepath.LastIndexOf("\\") + 1);
                        string serverpath = Server.MapPath("images/") + filename;
                        FileUpload1.PostedFile.SaveAs(serverpath);
                        this.lb_info.Text = "上传成功!";
                    }
                    else
                    {
                        this.lb_info.Text = "请上传图片";
                    }
                }
            }
            catch (Exception error)
            {
                this.lb_info.Text = "上传发生错误!原因:" + error.ToString();
            }
        }
        public static bool IsAllowedExtension(FileUpload hifile)
        {
            System.IO.FileStream fs = new System.IO.FileStream(hifile.PostedFile.FileName, System.IO.FileMode.Open, System.IO.FileAccess.Read);
            System.IO.BinaryReader r = new System.IO.BinaryReader(fs);
            string fileclass = "";
            byte buffer;
            try
            {
                buffer = r.ReadByte();
                fileclass = buffer.ToString();
                buffer = r.ReadByte();
                fileclass += buffer.ToString();        }
            catch
            {
              
            }
            r.Close();
            fs.Close();
            if (fileclass == "255216" || fileclass == "7173")//说明255216是jpg;7173是gif;6677是BMP,13780是PNG;7790是exe,8297是rar
            {
                return true;
            }
            else
            {
                return false;
            }    }  }