ligerUI利用a标签下载文件

一、利用WriteFile实现下载,并验证文件是否存在,将指定的文件直接写入HTTP响应输出流。注意:大型文件使用此方法可能导致异常。可以使用此方法的文件大小取决于 Web 服务器的硬件配置、

(1)为a标签添加onclick事件,其中fileId为文件guid编号,fileName为文件名称

<a href="javascript:void(0);" onclick="DownEntFiles(fileId,fileName)">下载</a>

(2)下载文件完整目录的方法

//下载接收文件
//fileId:文件id
//fileName:文件名称
function DownEntFiles(fileId, fileName) {
    $.ajax({
        type: 'post',
        url: '../HGSWXTManagement/isDeleteFiles',//后台处理的地址,用于判断该文件是否存在
        data: "{fileID:'" + fileId + "'}",
        async: false,
        contentType: 'application/json;charset=utf-8',
        success: function (data) {
            if (data == "") {
                $.ligerDialog.warn("该文件已删除,无法下载");
            }
            else {
                location.href = '../InfoStatistics/DownloadFiles?filePath=' + data + '&fileName=' + fileName + '';
            }
        }
    })
}

判断文件是否存在,如果存在,返回完整的文件路径

 #region 判断该文件是否已经删除,如果存在返回文件的完整路径
        public string isDeleteFiles(string fileID)
        {
            try
            {
                //判断文件夹下是否存在这个文件
                List<string> list =GetExcelFile(fileID, FunGuid);
                if (list.Count > 0)
                {
                    return list[0];
                }
                else
                {
                    return "";
                }
            }
            catch (Exception ex)
            {           
                return "";
            }
        }
        #endregion            

获取指定文件夹下存在的该文件的完整路径

#region 获取文件的路径以及后缀名
        /// <summary>
        /// 获取文件的路径以及后缀名
        /// </summary>
        /// <param name="fileName">文件名</param>
        /// <returns></returns>
        public List<string> GetExcelFile(string fileName,string FunGuid)
        {
            List<string> list = new List<string>();
            try
            {
                //获取web.config中配置的文件路径
                string filePath = System.Configuration.ConfigurationManager.AppSettings["UcRecv"].ToString();
                //设置要获取的文件路径
                //string path = HttpRuntime.AppDomainAppPath.ToString() + uploadFiles + "\\";
                DirectoryInfo root = new DirectoryInfo(filePath);
                FileInfo[] files = root.GetFiles();               
                //将文件夹下面的文件全部读取出来,并添加到list中
                for (var i = 0; i < files.Length; i++)
                {                  
                    if (files[i].Name==fileName)
                    {
                        list.Add(files[i].FullName);//添加相对路径                        
                    }
                }               
                return list;
            }
            catch (Exception ex)
            {               
                return list;
            }
        }
        #endregion

(3)下载文件

 #region 下载文件
        /// <summary>
        /// 下载文件
        /// </summary>
        /// <param name="filePath">文件完整路径</param>
        /// <param name="fileName">文件名</param>     
        public void DownloadFiles(string filePath, string fileName)
        {
            try
            {
                FileInfo fi = new FileInfo(filePath);
                Response.Clear();
                Response.ClearHeaders();
                Response.Buffer = false;
                //Response.AppendHeader("Content-Disposition", "attachment;filename=" + fileName);
//必须设置文件名称格式,否则在ie中会成乱码 Response.AddHeader("Content-Disposition", string.Format("attachment;filename*=utf-8''{0}", HttpUtility.UrlPathEncode(fileName))); Response.AppendHeader("Content-Length", fi.Length.ToString()); Response.HeaderEncoding = System.Text.Encoding.UTF8; Response.ContentEncoding = System.Text.Encoding.UTF8; Response.ContentType = "application/octet-stream"; Response.WriteFile(filePath); Response.Flush(); Response.End(); } catch (Exception ex) { throw ex; } } #endregion

二、流方式下载,(这里不对文件是否存在进行验证,如果验证,可以参考上面的方法

 

<a href='../PhoneNum/DownloadFiles?filePath=" + filePath + "&fileName=" + fileName + "'>下载</a>
/*filePath:文件路径
fileName:文件名称
*/

 

后台处理方法:

#region 下载excel文件
        /// <summary>
        /// 下载excel文件
        /// </summary>
        /// <param name="filePath">文件路径</param>
        /// <param name="fileName">文件名</param>
        /// <returns></returns>
        public FileStreamResult DownloadFiles(string filePath, string fileName)
        {           //获取文件的路径
             string localPath = Server.MapPath(filePath);
             return File(new FileStream(localPath, FileMode.Open), "text/plain", fileName);                        
        }
        #endregion

 

 

这样编写之后,文件能正常下载,图片,视频会直接打开,excel、txt、ppt等会保存

学习积累,如有问题,请留言,不胜感激,谢谢

posted @ 2019-03-05 14:48  SAS、A  阅读(284)  评论(0编辑  收藏  举报