文件的上傳(表單上傳和ajax文件異步上傳)


         項目中用戶上傳總是少不了的,下面就主要的列舉一下表單上傳和ajax上傳!注意: context.Request.Files不適合對大文件進行操作,下面列舉的主要對於小文件上傳的處理!

資源下載:

一.jQuery官方下載地址:https://jquery.com/download/

 

一.表單上傳:

html客戶端部分:

<form action="upload.ashx" method="post" enctype="multipart/form-data">
        選擇文件:<input type="file" name="file1" /><br />
        <input type="submit" value="上傳" />
    </form>

一般處理程序服務器端:

復制代碼
  public void ProcessRequest(HttpContext context)
        {
            context.Response.ContentType = "text/plain";
            HttpPostedFile file1 = context.Request.Files["file1"];
            helper.uploadFile(file1, "~/upload/");//這里就是對相應方法進行調用
            context.Response.Write("ok");//提示執行成功
        }
復制代碼

上傳代碼的封裝:

復制代碼
/// <summary>
        /// 上傳圖片
        /// </summary>
        /// <param name="file">通過form表達提交的文件</param>
        /// <param name="virpath">文件要保存的虛擬路徑</param>
        public static void uploadImg(HttpPostedFile file,string virpath)
        {          
            if (file.ContentLength > 1024 * 1024 * 4)
            {
                throw new Exception("文件不能大於4M");
            }
            string imgtype = Path.GetExtension(file.FileName);
            if(imgtype!=".jpg"&&imgtype!=".jpeg")  //圖片類型進行限制
            {
                throw new Exception("請上傳jpg或JPEG圖片");
            }
            using (Image img = Bitmap.FromStream(file.InputStream))
            {
                string savepath = HttpContext.Current.Server.MapPath(virpath+file.FileName);
                img.Save(savepath);
            }
        }
        /// <summary>
        /// 上傳文件
        /// </summary>
        /// <param name="file">通過form表達提交的文件</param>
        /// <param name="virpath">文件要保存的虛擬路徑</param>
        public static void uploadFile(HttpPostedFile file, string virpath)
        {
            if (file.ContentLength > 1024 * 1024 * 6)
            {
                throw new Exception("文件不能大於6M");
            }
            string imgtype = Path.GetExtension(file.FileName);
            //imgtype對上傳的文件進行限制
            if (imgtype != ".zip" && imgtype != ".mp3")
            {
                throw new Exception("只允許上傳zip、rar....文件");
            }
            string dirFullPath=  HttpContext.Current.Server.MapPath(virpath);
            if (!Directory.Exists(dirFullPath))//如果文件夾不存在,則先創建文件夾
            {
                Directory.CreateDirectory(dirFullPath);
            }
            file.SaveAs(dirFullPath + file.FileName);
        }
復制代碼

二.Ajax文件異步上傳:

 注明:既然有了表單上傳為什么又要ajax上傳呢?因為表單上傳過程中,整個頁面就刷新了!ajax異步上傳就可以達到只刷新局部位置,下面就簡單看看ajax上傳吧!

html客戶端部分:

復制代碼
<head> 
<script src="jquery-2.1.4.js"></script>
    <script>
        $(function () {
            $("#upload").click(function () {
                $("#imgWait").show();
                var formData = new FormData();
                formData.append("myfile", document.getElementById("file1").files[0]);   
                $.ajax({
                    url: "upload.ashx",
                    type: "POST",
                    data: formData,
                    /**
                    *必須false才會自動加上正確的Content-Type
                    */
                    contentType: false,
                    /**
                    * 必須false才會避開jQuery對 formdata 的默認處理
                    * XMLHttpRequest會對 formdata 進行正確的處理
                    */
                    processData: false,
                    success: function (data) {
                        if (data.status == "true") {
                            alert("上傳成功!");
                        }
                        if (data.status == "error") {
                            alert(data.msg);
                        }
                        $("#imgWait").hide();
                    },
                    error: function () {
                        alert("上傳失敗!");
                        $("#imgWait").hide();
                    }
                });
            });
        });
    </script>
</head>
<body>   
        選擇文件:<input type="file" id="file1" /><br />
        <input type="button" id="upload" value="上傳" />
        <img src="wait.gif" style="display:none" id="imgWait" />   
</body>
復制代碼

 

一般處理程序服務器端:

復制代碼
public void ProcessRequest(HttpContext context)
        {
            context.Response.ContentType = "text/html";
            if (context.Request.Files.Count > 0)
            {
                HttpPostedFile file1 = context.Request.Files["myfile"];
                helper.uploadFile(file1, "~/upload/");  //這里引用的是上面封裝的方法
                WriteJson(context.Response, "true", "");
            }
            else
            {
                WriteJson(context.Response, "error", "請選擇要上傳的文件");
            }
        }
復制代碼

json代碼封裝:

復制代碼
public static void WriteJson(HttpResponse response,
           string status1, string msg1, object data1 = null)
        {
            response.ContentType = "application/json";
            var obj = new { status = status1, msg = msg1, data = data1 };
            string json = new JavaScriptSerializer().Serialize(obj);
            response.Write(json);
        }
復制代碼

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM